{"ast":null,"code":"import _asyncToGenerator from \"F:/workspace/202226701027/huinongbao-app/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\";\nimport { Observable } from \"./observable.js\";\nimport { GetDOMTextContent, IsNavigatorAvailable, IsWindowObjectExist } from \"./domManagement.js\";\nimport { Logger } from \"./logger.js\";\nimport { DeepCopier } from \"./deepCopier.js\";\nimport { PrecisionDate } from \"./precisionDate.js\";\nimport { _WarnImport } from \"./devTools.js\";\nimport { WebRequest } from \"./webRequest.js\";\nimport { EngineStore } from \"../Engines/engineStore.js\";\nimport { FileToolsOptions, DecodeBase64UrlToBinary, IsBase64DataUrl, LoadFile as FileToolsLoadFile, LoadImage as FileToolLoadImage, ReadFile as FileToolsReadFile, SetCorsBehavior } from \"./fileTools.js\";\nimport { TimingTools } from \"./timingTools.js\";\nimport { InstantiationTools } from \"./instantiationTools.js\";\nimport { RandomGUID } from \"./guid.js\";\nimport { IsExponentOfTwo, Mix } from \"./tools.functions.js\";\n/**\n * Class containing a set of static utilities functions\n */\nexport class Tools {\n /**\n * Gets or sets the base URL to use to load assets\n */\n static get BaseUrl() {\n return FileToolsOptions.BaseUrl;\n }\n static set BaseUrl(value) {\n FileToolsOptions.BaseUrl = value;\n }\n /**\n * Gets or sets the clean URL function to use to load assets\n */\n static get CleanUrl() {\n return FileToolsOptions.CleanUrl;\n }\n static set CleanUrl(value) {\n FileToolsOptions.CleanUrl = value;\n }\n /**\n * This function checks whether a URL is absolute or not.\n * It will also detect data and blob URLs\n * @param url the url to check\n * @returns is the url absolute or relative\n */\n static IsAbsoluteUrl(url) {\n // See https://stackoverflow.com/a/38979205.\n // URL is protocol-relative (= absolute)\n if (url.indexOf(\"//\") === 0) {\n return true;\n }\n // URL has no protocol (= relative)\n if (url.indexOf(\"://\") === -1) {\n return false;\n }\n // URL does not contain a dot, i.e. no TLD (= relative, possibly REST)\n if (url.indexOf(\".\") === -1) {\n return false;\n }\n // URL does not contain a single slash (= relative)\n if (url.indexOf(\"/\") === -1) {\n return false;\n }\n // The first colon comes after the first slash (= relative)\n if (url.indexOf(\":\") > url.indexOf(\"/\")) {\n return false;\n }\n // Protocol is defined before first dot (= absolute)\n if (url.indexOf(\"://\") < url.indexOf(\".\")) {\n return true;\n }\n if (url.indexOf(\"data:\") === 0 || url.indexOf(\"blob:\") === 0) {\n return true;\n }\n // Anything else must be relative\n return false;\n }\n /**\n * Sets the base URL to use to load scripts\n */\n static set ScriptBaseUrl(value) {\n FileToolsOptions.ScriptBaseUrl = value;\n }\n static get ScriptBaseUrl() {\n return FileToolsOptions.ScriptBaseUrl;\n }\n /**\n * Sets a preprocessing function to run on a source URL before importing it\n * Note that this function will execute AFTER the base URL is appended to the URL\n */\n static set ScriptPreprocessUrl(func) {\n FileToolsOptions.ScriptPreprocessUrl = func;\n }\n static get ScriptPreprocessUrl() {\n return FileToolsOptions.ScriptPreprocessUrl;\n }\n /**\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\n */\n static get DefaultRetryStrategy() {\n return FileToolsOptions.DefaultRetryStrategy;\n }\n static set DefaultRetryStrategy(strategy) {\n FileToolsOptions.DefaultRetryStrategy = strategy;\n }\n /**\n * Default behavior for cors in the application.\n * It can be a string if the expected behavior is identical in the entire app.\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)\n */\n static get CorsBehavior() {\n return FileToolsOptions.CorsBehavior;\n }\n static set CorsBehavior(value) {\n FileToolsOptions.CorsBehavior = value;\n }\n /**\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\n * @ignorenaming\n */\n static get UseFallbackTexture() {\n return EngineStore.UseFallbackTexture;\n }\n static set UseFallbackTexture(value) {\n EngineStore.UseFallbackTexture = value;\n }\n /**\n * Use this object to register external classes like custom textures or material\n * to allow the loaders to instantiate them\n */\n static get RegisteredExternalClasses() {\n return InstantiationTools.RegisteredExternalClasses;\n }\n static set RegisteredExternalClasses(classes) {\n InstantiationTools.RegisteredExternalClasses = classes;\n }\n /**\n * Texture content used if a texture cannot loaded\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static get fallbackTexture() {\n return EngineStore.FallbackTexture;\n }\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static set fallbackTexture(value) {\n EngineStore.FallbackTexture = value;\n }\n /**\n * Read the content of a byte array at a specified coordinates (taking in account wrapping)\n * @param u defines the coordinate on X axis\n * @param v defines the coordinate on Y axis\n * @param width defines the width of the source data\n * @param height defines the height of the source data\n * @param pixels defines the source byte array\n * @param color defines the output color\n */\n static FetchToRef(u, v, width, height, pixels, color) {\n const wrappedU = Math.abs(u) * width % width | 0;\n const wrappedV = Math.abs(v) * height % height | 0;\n const position = (wrappedU + wrappedV * width) * 4;\n color.r = pixels[position] / 255;\n color.g = pixels[position + 1] / 255;\n color.b = pixels[position + 2] / 255;\n color.a = pixels[position + 3] / 255;\n }\n /**\n * Interpolates between a and b via alpha\n * @param a The lower value (returned when alpha = 0)\n * @param b The upper value (returned when alpha = 1)\n * @param alpha The interpolation-factor\n * @returns The mixed value\n */\n static Mix(a, b, alpha) {\n return 0;\n }\n /**\n * Tries to instantiate a new object from a given class name\n * @param className defines the class name to instantiate\n * @returns the new object or null if the system was not able to do the instantiation\n */\n static Instantiate(className) {\n return InstantiationTools.Instantiate(className);\n }\n /**\n * Polyfill for setImmediate\n * @param action defines the action to execute after the current execution block\n */\n static SetImmediate(action) {\n TimingTools.SetImmediate(action);\n }\n /**\n * Function indicating if a number is an exponent of 2\n * @param value defines the value to test\n * @returns true if the value is an exponent of 2\n */\n static IsExponentOfTwo(value) {\n return true;\n }\n /**\n * Returns the nearest 32-bit single precision float representation of a Number\n * @param value A Number. If the parameter is of a different type, it will get converted\n * to a number or to NaN if it cannot be converted\n * @returns number\n */\n static FloatRound(value) {\n return Math.fround(value);\n }\n /**\n * Extracts the filename from a path\n * @param path defines the path to use\n * @returns the filename\n */\n static GetFilename(path) {\n const index = path.lastIndexOf(\"/\");\n if (index < 0) {\n return path;\n }\n return path.substring(index + 1);\n }\n /**\n * Extracts the \"folder\" part of a path (everything before the filename).\n * @param uri The URI to extract the info from\n * @param returnUnchangedIfNoSlash Do not touch the URI if no slashes are present\n * @returns The \"folder\" part of the path\n */\n static GetFolderPath(uri, returnUnchangedIfNoSlash = false) {\n const index = uri.lastIndexOf(\"/\");\n if (index < 0) {\n if (returnUnchangedIfNoSlash) {\n return uri;\n }\n return \"\";\n }\n return uri.substring(0, index + 1);\n }\n /**\n * Convert an angle in radians to degrees\n * @param angle defines the angle to convert\n * @returns the angle in degrees\n */\n static ToDegrees(angle) {\n return angle * 180 / Math.PI;\n }\n /**\n * Convert an angle in degrees to radians\n * @param angle defines the angle to convert\n * @returns the angle in radians\n */\n static ToRadians(angle) {\n return angle * Math.PI / 180;\n }\n /**\n * Smooth angle changes (kind of low-pass filter), in particular for device orientation \"shaking\"\n * Use trigonometric functions to avoid discontinuity (0/360, -180/180)\n * @param previousAngle defines last angle value, in degrees\n * @param newAngle defines new angle value, in degrees\n * @param smoothFactor defines smoothing sensitivity; min 0: no smoothing, max 1: new data ignored\n * @returns the angle in degrees\n */\n static SmoothAngleChange(previousAngle, newAngle, smoothFactor = 0.9) {\n const previousAngleRad = this.ToRadians(previousAngle);\n const newAngleRad = this.ToRadians(newAngle);\n return this.ToDegrees(Math.atan2((1 - smoothFactor) * Math.sin(newAngleRad) + smoothFactor * Math.sin(previousAngleRad), (1 - smoothFactor) * Math.cos(newAngleRad) + smoothFactor * Math.cos(previousAngleRad)));\n }\n /**\n * Returns an array if obj is not an array\n * @param obj defines the object to evaluate as an array\n * @param allowsNullUndefined defines a boolean indicating if obj is allowed to be null or undefined\n * @returns either obj directly if obj is an array or a new array containing obj\n */\n static MakeArray(obj, allowsNullUndefined) {\n if (allowsNullUndefined !== true && (obj === undefined || obj == null)) {\n return null;\n }\n return Array.isArray(obj) ? obj : [obj];\n }\n /**\n * Gets the pointer prefix to use\n * @param engine defines the engine we are finding the prefix for\n * @returns \"pointer\" if touch is enabled. Else returns \"mouse\"\n */\n static GetPointerPrefix(engine) {\n return IsWindowObjectExist() && !window.PointerEvent ? \"mouse\" : \"pointer\";\n }\n /**\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\n * @param url define the url we are trying\n * @param element define the dom element where to configure the cors policy\n * @param element.crossOrigin\n */\n static SetCorsBehavior(url, element) {\n SetCorsBehavior(url, element);\n }\n /**\n * Sets the referrerPolicy behavior on a dom element.\n * @param referrerPolicy define the referrer policy to use\n * @param element define the dom element where to configure the referrer policy\n * @param element.referrerPolicy\n */\n static SetReferrerPolicyBehavior(referrerPolicy, element) {\n element.referrerPolicy = referrerPolicy;\n }\n // External files\n /**\n * Gets or sets a function used to pre-process url before using them to load assets\n */\n static get PreprocessUrl() {\n return FileToolsOptions.PreprocessUrl;\n }\n static set PreprocessUrl(processor) {\n FileToolsOptions.PreprocessUrl = processor;\n }\n /**\n * Loads an image as an HTMLImageElement.\n * @param input url string, ArrayBuffer, or Blob to load\n * @param onLoad callback called when the image successfully loads\n * @param onError callback called when the image fails to load\n * @param offlineProvider offline provider for caching\n * @param mimeType optional mime type\n * @param imageBitmapOptions optional the options to use when creating an ImageBitmap\n * @returns the HTMLImageElement of the loaded image\n */\n static LoadImage(input, onLoad, onError, offlineProvider, mimeType, imageBitmapOptions) {\n return FileToolLoadImage(input, onLoad, onError, offlineProvider, mimeType, imageBitmapOptions);\n }\n /**\n * Loads a file from a url\n * @param url url string, ArrayBuffer, or Blob to load\n * @param onSuccess callback called when the file successfully loads\n * @param onProgress callback called while file is loading (if the server supports this mode)\n * @param offlineProvider defines the offline provider for caching\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\n * @param onError callback called when the file fails to load\n * @returns a file request object\n */\n static LoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\n return FileToolsLoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\n }\n /**\n * Loads a file from a url\n * @param url the file url to load\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\n * @returns a promise containing an ArrayBuffer corresponding to the loaded file\n */\n static LoadFileAsync(url, useArrayBuffer = true) {\n return new Promise((resolve, reject) => {\n FileToolsLoadFile(url, data => {\n resolve(data);\n }, undefined, undefined, useArrayBuffer, (request, exception) => {\n reject(exception);\n });\n });\n }\n /**\n * Get a script URL including preprocessing\n * @param scriptUrl the script Url to process\n * @param forceAbsoluteUrl force the script to be an absolute url (adding the current base url if necessary)\n * @returns a modified URL to use\n */\n static GetBabylonScriptURL(scriptUrl, forceAbsoluteUrl) {\n if (!scriptUrl) {\n return \"\";\n }\n // if the base URL was set, and the script Url is an absolute path change the default path\n if (Tools.ScriptBaseUrl && scriptUrl.startsWith(Tools._DefaultCdnUrl)) {\n // change the default host, which is https://cdn.babylonjs.com with the one defined\n // make sure no trailing slash is present\n const baseUrl = Tools.ScriptBaseUrl[Tools.ScriptBaseUrl.length - 1] === \"/\" ? Tools.ScriptBaseUrl.substring(0, Tools.ScriptBaseUrl.length - 1) : Tools.ScriptBaseUrl;\n scriptUrl = scriptUrl.replace(Tools._DefaultCdnUrl, baseUrl);\n }\n // run the preprocessor\n scriptUrl = Tools.ScriptPreprocessUrl(scriptUrl);\n if (forceAbsoluteUrl) {\n scriptUrl = Tools.GetAbsoluteUrl(scriptUrl);\n }\n return scriptUrl;\n }\n /**\n * This function is used internally by babylon components to load a script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param onSuccess defines the callback called when the script is loaded\n * @param onError defines the callback to call if an error occurs\n * @param scriptId defines the id of the script element\n */\n static LoadBabylonScript(scriptUrl, onSuccess, onError, scriptId) {\n scriptUrl = Tools.GetBabylonScriptURL(scriptUrl);\n Tools.LoadScript(scriptUrl, onSuccess, onError);\n }\n /**\n * Load an asynchronous script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to laod\n * @returns a promise request object\n */\n static LoadBabylonScriptAsync(scriptUrl) {\n scriptUrl = Tools.GetBabylonScriptURL(scriptUrl);\n return Tools.LoadScriptAsync(scriptUrl);\n }\n /**\n * This function is used internally by babylon components to load a script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param onSuccess defines the callback called when the script is loaded\n * @param onError defines the callback to call if an error occurs\n * @param scriptId defines the id of the script element\n * @param useModule defines if we should use the module strategy to load the script\n */\n static LoadScript(scriptUrl, onSuccess, onError, scriptId, useModule = false) {\n if (typeof importScripts === \"function\") {\n try {\n importScripts(scriptUrl);\n if (onSuccess) {\n onSuccess();\n }\n } catch (e) {\n onError === null || onError === void 0 || onError(`Unable to load script '${scriptUrl}' in worker`, e);\n }\n return;\n } else if (!IsWindowObjectExist()) {\n onError === null || onError === void 0 || onError(`Cannot load script '${scriptUrl}' outside of a window or a worker`);\n return;\n }\n const head = document.getElementsByTagName(\"head\")[0];\n const script = document.createElement(\"script\");\n if (useModule) {\n script.setAttribute(\"type\", \"module\");\n script.innerText = scriptUrl;\n } else {\n script.setAttribute(\"type\", \"text/javascript\");\n script.setAttribute(\"src\", scriptUrl);\n }\n if (scriptId) {\n script.id = scriptId;\n }\n script.onload = () => {\n if (onSuccess) {\n onSuccess();\n }\n };\n script.onerror = e => {\n if (onError) {\n onError(`Unable to load script '${scriptUrl}'`, e);\n }\n };\n head.appendChild(script);\n }\n /**\n * Load an asynchronous script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param scriptId defines the id of the script element\n * @returns a promise request object\n */\n static LoadScriptAsync(scriptUrl, scriptId) {\n return new Promise((resolve, reject) => {\n this.LoadScript(scriptUrl, () => {\n resolve();\n }, (message, exception) => {\n reject(exception || new Error(message));\n }, scriptId);\n });\n }\n /**\n * Loads a file from a blob\n * @param fileToLoad defines the blob to use\n * @param callback defines the callback to call when data is loaded\n * @param progressCallback defines the callback to call during loading process\n * @returns a file request object\n */\n static ReadFileAsDataURL(fileToLoad, callback, progressCallback) {\n const reader = new FileReader();\n const request = {\n onCompleteObservable: new Observable(),\n abort: () => reader.abort()\n };\n reader.onloadend = () => {\n request.onCompleteObservable.notifyObservers(request);\n };\n reader.onload = e => {\n //target doesn't have result from ts 1.3\n callback(e.target[\"result\"]);\n };\n reader.onprogress = progressCallback;\n reader.readAsDataURL(fileToLoad);\n return request;\n }\n /**\n * Reads a file from a File object\n * @param file defines the file to load\n * @param onSuccess defines the callback to call when data is loaded\n * @param onProgress defines the callback to call during loading process\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\n * @param onError defines the callback to call when an error occurs\n * @returns a file request object\n */\n static ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError) {\n return FileToolsReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\n }\n /**\n * Creates a data url from a given string content\n * @param content defines the content to convert\n * @returns the new data url link\n */\n static FileAsURL(content) {\n const fileBlob = new Blob([content]);\n const url = window.URL;\n const link = url.createObjectURL(fileBlob);\n return link;\n }\n /**\n * Format the given number to a specific decimal format\n * @param value defines the number to format\n * @param decimals defines the number of decimals to use\n * @returns the formatted string\n */\n static Format(value, decimals = 2) {\n return value.toFixed(decimals);\n }\n /**\n * Tries to copy an object by duplicating every property\n * @param source defines the source object\n * @param destination defines the target object\n * @param doNotCopyList defines a list of properties to avoid\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\n */\n static DeepCopy(source, destination, doNotCopyList, mustCopyList) {\n DeepCopier.DeepCopy(source, destination, doNotCopyList, mustCopyList);\n }\n /**\n * Gets a boolean indicating if the given object has no own property\n * @param obj defines the object to test\n * @returns true if object has no own property\n */\n static IsEmpty(obj) {\n for (const i in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, i)) {\n return false;\n }\n }\n return true;\n }\n /**\n * Function used to register events at window level\n * @param windowElement defines the Window object to use\n * @param events defines the events to register\n */\n static RegisterTopRootEvents(windowElement, events) {\n for (let index = 0; index < events.length; index++) {\n const event = events[index];\n windowElement.addEventListener(event.name, event.handler, false);\n try {\n if (window.parent) {\n window.parent.addEventListener(event.name, event.handler, false);\n }\n } catch (e) {\n // Silently fails...\n }\n }\n }\n /**\n * Function used to unregister events from window level\n * @param windowElement defines the Window object to use\n * @param events defines the events to unregister\n */\n static UnregisterTopRootEvents(windowElement, events) {\n for (let index = 0; index < events.length; index++) {\n const event = events[index];\n windowElement.removeEventListener(event.name, event.handler);\n try {\n if (windowElement.parent) {\n windowElement.parent.removeEventListener(event.name, event.handler);\n }\n } catch (e) {\n // Silently fails...\n }\n }\n }\n /**\n * Dumps the current bound framebuffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param engine defines the hosting engine\n * @param successCallback defines the callback triggered once the data are available\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns a void promise\n */\n static DumpFramebuffer(width, height, engine, successCallback, mimeType = \"image/png\", fileName, quality) {\n return _asyncToGenerator(function* () {\n throw _WarnImport(\"DumpTools\");\n })();\n }\n /**\n * Dumps an array buffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param data the data array\n * @param successCallback defines the callback triggered once the data are available\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param invertY true to invert the picture in the Y dimension\n * @param toArrayBuffer true to convert the data to an ArrayBuffer (encoded as `mimeType`) instead of a base64 string\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static DumpData(width, height, data, successCallback, mimeType = \"image/png\", fileName, invertY = false, toArrayBuffer = false, quality) {\n throw _WarnImport(\"DumpTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Dumps an array buffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param data the data array\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param invertY true to invert the picture in the Y dimension\n * @param toArrayBuffer true to convert the data to an ArrayBuffer (encoded as `mimeType`) instead of a base64 string\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns a promise that resolve to the final data\n */\n static DumpDataAsync(width, height, data, mimeType = \"image/png\", fileName, invertY = false, toArrayBuffer = false, quality) {\n throw _WarnImport(\"DumpTools\");\n }\n static _IsOffScreenCanvas(canvas) {\n return canvas.convertToBlob !== undefined;\n }\n /**\n * Converts the canvas data to blob.\n * This acts as a polyfill for browsers not supporting the to blob function.\n * @param canvas Defines the canvas to extract the data from (can be an offscreen canvas)\n * @param successCallback Defines the callback triggered once the data are available\n * @param mimeType Defines the mime type of the result\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static ToBlob(canvas, successCallback, mimeType = \"image/png\", quality) {\n // We need HTMLCanvasElement.toBlob for HD screenshots\n if (!Tools._IsOffScreenCanvas(canvas) && !canvas.toBlob) {\n // low performance polyfill based on toDataURL (https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob)\n canvas.toBlob = function (callback, type, quality) {\n setTimeout(() => {\n const binStr = atob(this.toDataURL(type, quality).split(\",\")[1]),\n len = binStr.length,\n arr = new Uint8Array(len);\n for (let i = 0; i < len; i++) {\n arr[i] = binStr.charCodeAt(i);\n }\n callback(new Blob([arr]));\n });\n };\n }\n if (Tools._IsOffScreenCanvas(canvas)) {\n canvas.convertToBlob({\n type: mimeType,\n quality\n }).then(blob => successCallback(blob));\n } else {\n canvas.toBlob(function (blob) {\n successCallback(blob);\n }, mimeType, quality);\n }\n }\n /**\n * Download a Blob object\n * @param blob the Blob object\n * @param fileName the file name to download\n */\n static DownloadBlob(blob, fileName) {\n //Creating a link if the browser have the download attribute on the a tag, to automatically start download generated image.\n if (\"download\" in document.createElement(\"a\")) {\n if (!fileName) {\n const date = new Date();\n const stringDate = (date.getFullYear() + \"-\" + (date.getMonth() + 1)).slice(2) + \"-\" + date.getDate() + \"_\" + date.getHours() + \"-\" + (\"0\" + date.getMinutes()).slice(-2);\n fileName = \"screenshot_\" + stringDate + \".png\";\n }\n Tools.Download(blob, fileName);\n } else {\n if (blob && typeof URL !== \"undefined\") {\n const url = URL.createObjectURL(blob);\n const newWindow = window.open(\"\");\n if (!newWindow) {\n return;\n }\n const img = newWindow.document.createElement(\"img\");\n img.onload = function () {\n // no longer need to read the blob so it's revoked\n URL.revokeObjectURL(url);\n };\n img.src = url;\n newWindow.document.body.appendChild(img);\n }\n }\n }\n /**\n * Encodes the canvas data to base 64, or automatically downloads the result if `fileName` is defined.\n * @param canvas The canvas to get the data from, which can be an offscreen canvas.\n * @param successCallback The callback which is triggered once the data is available. If `fileName` is defined, the callback will be invoked after the download occurs, and the `data` argument will be an empty string.\n * @param mimeType The mime type of the result.\n * @param fileName The name of the file to download. If defined, the result will automatically be downloaded. If not defined, and `successCallback` is also not defined, the result will automatically be downloaded with an auto-generated file name.\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static EncodeScreenshotCanvasData(canvas, successCallback, mimeType = \"image/png\", fileName, quality) {\n if (typeof fileName === \"string\" || !successCallback) {\n this.ToBlob(canvas, function (blob) {\n if (blob) {\n Tools.DownloadBlob(blob, fileName);\n }\n if (successCallback) {\n successCallback(\"\");\n }\n }, mimeType, quality);\n } else if (successCallback) {\n if (Tools._IsOffScreenCanvas(canvas)) {\n canvas.convertToBlob({\n type: mimeType,\n quality\n }).then(blob => {\n const reader = new FileReader();\n reader.readAsDataURL(blob);\n reader.onloadend = () => {\n const base64data = reader.result;\n successCallback(base64data);\n };\n });\n return;\n }\n const base64Image = canvas.toDataURL(mimeType, quality);\n successCallback(base64Image);\n }\n }\n /**\n * Downloads a blob in the browser\n * @param blob defines the blob to download\n * @param fileName defines the name of the downloaded file\n */\n static Download(blob, fileName) {\n if (typeof URL === \"undefined\") {\n return;\n }\n const url = window.URL.createObjectURL(blob);\n const a = document.createElement(\"a\");\n document.body.appendChild(a);\n a.style.display = \"none\";\n a.href = url;\n a.download = fileName;\n a.addEventListener(\"click\", () => {\n if (a.parentElement) {\n a.parentElement.removeChild(a);\n }\n });\n a.click();\n window.URL.revokeObjectURL(url);\n }\n /**\n * Will return the right value of the noPreventDefault variable\n * Needed to keep backwards compatibility to the old API.\n *\n * @param args arguments passed to the attachControl function\n * @returns the correct value for noPreventDefault\n */\n static BackCompatCameraNoPreventDefault(args) {\n // is it used correctly?\n if (typeof args[0] === \"boolean\") {\n return args[0];\n } else if (typeof args[1] === \"boolean\") {\n return args[1];\n }\n return false;\n }\n /**\n * Captures a screenshot of the current rendering\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine defines the rendering engine\n * @param camera defines the source camera\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param successCallback defines the callback receives a single parameter which contains the\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\n * src parameter of an to display it\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param forceDownload force the system to download the image even if a successCallback is provided\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshot(engine, camera, size, successCallback, mimeType = \"image/png\", forceDownload = false, quality) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Captures a screenshot of the current rendering\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine defines the rendering engine\n * @param camera defines the source camera\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\n * to the src parameter of an to display it\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotAsync(engine, camera, size, mimeType = \"image/png\", quality) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n /**\n * Generates an image screenshot from the specified camera.\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine The engine to use for rendering\n * @param camera The camera to use for rendering\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param successCallback The callback receives a single parameter which contains the\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\n * src parameter of an to display it\n * @param mimeType The MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param samples Texture samples (default: 1)\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\n * @param fileName A name for for the downloaded file.\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\n * @param enableStencilBuffer Whether the stencil buffer should be enabled or not (default: false)\n * @param useLayerMask if the camera's layer mask should be used to filter what should be rendered (default: true)\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @param customizeTexture An optional callback that can be used to modify the render target texture before taking the screenshot. This can be used, for instance, to enable camera post-processes before taking the screenshot.\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotUsingRenderTarget(engine, camera, size, successCallback, mimeType = \"image/png\", samples = 1, antialiasing = false, fileName, renderSprites = false, enableStencilBuffer = false, useLayerMask = true, quality, customizeTexture) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Generates an image screenshot from the specified camera.\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine The engine to use for rendering\n * @param camera The camera to use for rendering\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param mimeType The MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param samples Texture samples (default: 1)\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\n * @param fileName A name for for the downloaded file.\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\n * @param enableStencilBuffer Whether the stencil buffer should be enabled or not (default: false)\n * @param useLayerMask if the camera's layer mask should be used to filter what should be rendered (default: true)\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @param customizeTexture An optional callback that can be used to modify the render target texture before taking the screenshot. This can be used, for instance, to enable camera post-processes before taking the screenshot.\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\n * to the src parameter of an to display it\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotUsingRenderTargetAsync(engine, camera, size, mimeType = \"image/png\", samples = 1, antialiasing = false, fileName, renderSprites = false, enableStencilBuffer = false, useLayerMask = true, quality, customizeTexture) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n /**\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\n * Be aware Math.random() could cause collisions, but:\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\"\n * @returns a pseudo random id\n */\n static RandomId() {\n return RandomGUID();\n }\n /**\n * Test if the given uri is a base64 string\n * @deprecated Please use FileTools.IsBase64DataUrl instead.\n * @param uri The uri to test\n * @returns True if the uri is a base64 string or false otherwise\n */\n static IsBase64(uri) {\n return IsBase64DataUrl(uri);\n }\n /**\n * Decode the given base64 uri.\n * @deprecated Please use FileTools.DecodeBase64UrlToBinary instead.\n * @param uri The uri to decode\n * @returns The decoded base64 data.\n */\n static DecodeBase64(uri) {\n return DecodeBase64UrlToBinary(uri);\n }\n /**\n * Gets a value indicating the number of loading errors\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static get errorsCount() {\n return Logger.errorsCount;\n }\n /**\n * Log a message to the console\n * @param message defines the message to log\n */\n static Log(message) {\n Logger.Log(message);\n }\n /**\n * Write a warning message to the console\n * @param message defines the message to log\n */\n static Warn(message) {\n Logger.Warn(message);\n }\n /**\n * Write an error message to the console\n * @param message defines the message to log\n */\n static Error(message) {\n Logger.Error(message);\n }\n /**\n * Gets current log cache (list of logs)\n */\n static get LogCache() {\n return Logger.LogCache;\n }\n /**\n * Clears the log cache\n */\n static ClearLogCache() {\n Logger.ClearLogCache();\n }\n /**\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\n */\n static set LogLevels(level) {\n Logger.LogLevels = level;\n }\n /**\n * Sets the current performance log level\n */\n static set PerformanceLogLevel(level) {\n if ((level & Tools.PerformanceUserMarkLogLevel) === Tools.PerformanceUserMarkLogLevel) {\n Tools.StartPerformanceCounter = Tools._StartUserMark;\n Tools.EndPerformanceCounter = Tools._EndUserMark;\n return;\n }\n if ((level & Tools.PerformanceConsoleLogLevel) === Tools.PerformanceConsoleLogLevel) {\n Tools.StartPerformanceCounter = Tools._StartPerformanceConsole;\n Tools.EndPerformanceCounter = Tools._EndPerformanceConsole;\n return;\n }\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static _StartPerformanceCounterDisabled(counterName, condition) {}\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static _EndPerformanceCounterDisabled(counterName, condition) {}\n static _StartUserMark(counterName, condition = true) {\n if (!Tools._Performance) {\n if (!IsWindowObjectExist()) {\n return;\n }\n Tools._Performance = window.performance;\n }\n if (!condition || !Tools._Performance.mark) {\n return;\n }\n Tools._Performance.mark(counterName + \"-Begin\");\n }\n static _EndUserMark(counterName, condition = true) {\n if (!condition || !Tools._Performance.mark) {\n return;\n }\n Tools._Performance.mark(counterName + \"-End\");\n Tools._Performance.measure(counterName, counterName + \"-Begin\", counterName + \"-End\");\n }\n static _StartPerformanceConsole(counterName, condition = true) {\n if (!condition) {\n return;\n }\n Tools._StartUserMark(counterName, condition);\n if (console.time) {\n console.time(counterName);\n }\n }\n static _EndPerformanceConsole(counterName, condition = true) {\n if (!condition) {\n return;\n }\n Tools._EndUserMark(counterName, condition);\n console.timeEnd(counterName);\n }\n /**\n * Gets either window.performance.now() if supported or Date.now() else\n */\n static get Now() {\n return PrecisionDate.Now;\n }\n /**\n * This method will return the name of the class used to create the instance of the given object.\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator.\n * @param object the object to get the class name from\n * @param isType defines if the object is actually a type\n * @returns the name of the class, will be \"object\" for a custom data type not using the @className decorator\n */\n static GetClassName(object, isType = false) {\n let name = null;\n if (!isType && object.getClassName) {\n name = object.getClassName();\n } else {\n if (object instanceof Object) {\n const classObj = isType ? object : Object.getPrototypeOf(object);\n name = classObj.constructor[\"__bjsclassName__\"];\n }\n if (!name) {\n name = typeof object;\n }\n }\n return name;\n }\n /**\n * Gets the first element of an array satisfying a given predicate\n * @param array defines the array to browse\n * @param predicate defines the predicate to use\n * @returns null if not found or the element\n */\n static First(array, predicate) {\n for (const el of array) {\n if (predicate(el)) {\n return el;\n }\n }\n return null;\n }\n /**\n * This method will return the name of the full name of the class, including its owning module (if any).\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).\n * @param object the object to get the class name from\n * @param isType defines if the object is actually a type\n * @returns 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.\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static getFullClassName(object, isType = false) {\n let className = null;\n let moduleName = null;\n if (!isType && object.getClassName) {\n className = object.getClassName();\n } else {\n if (object instanceof Object) {\n const classObj = isType ? object : Object.getPrototypeOf(object);\n className = classObj.constructor[\"__bjsclassName__\"];\n moduleName = classObj.constructor[\"__bjsmoduleName__\"];\n }\n if (!className) {\n className = typeof object;\n }\n }\n if (!className) {\n return null;\n }\n return (moduleName != null ? moduleName + \".\" : \"\") + className;\n }\n /**\n * Returns a promise that resolves after the given amount of time.\n * @param delay Number of milliseconds to delay\n * @returns Promise that resolves after the given amount of time\n */\n static DelayAsync(delay) {\n return new Promise(resolve => {\n setTimeout(() => {\n resolve();\n }, delay);\n });\n }\n /**\n * Utility function to detect if the current user agent is Safari\n * @returns whether or not the current user agent is safari\n */\n static IsSafari() {\n if (!IsNavigatorAvailable()) {\n return false;\n }\n return /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\n }\n}\n/**\n * Enable/Disable Custom HTTP Request Headers globally.\n * default = false\n * @see CustomRequestHeaders\n */\nTools.UseCustomRequestHeaders = false;\n/**\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\n * i.e. when loading files, where the server/service expects an Authorization header\n */\nTools.CustomRequestHeaders = WebRequest.CustomRequestHeaders;\n/**\n * Extracts text content from a DOM element hierarchy\n * Back Compat only, please use GetDOMTextContent instead.\n */\nTools.GetDOMTextContent = GetDOMTextContent;\n/**\n * @internal\n */\nTools._DefaultCdnUrl = \"https://cdn.babylonjs.com\";\n// eslint-disable-next-line jsdoc/require-returns-check, jsdoc/require-param\n/**\n * @returns the absolute URL of a given (relative) url\n */\nTools.GetAbsoluteUrl = typeof document === \"object\" ? url => {\n const a = document.createElement(\"a\");\n a.href = url;\n return a.href;\n} : typeof URL === \"function\" && typeof location === \"object\" ? url => new URL(url, location.origin).href : () => {\n throw new Error(\"Unable to get absolute URL. Override BABYLON.Tools.GetAbsoluteUrl to a custom implementation for the current context.\");\n};\n// Logs\n/**\n * No log\n */\nTools.NoneLogLevel = Logger.NoneLogLevel;\n/**\n * Only message logs\n */\nTools.MessageLogLevel = Logger.MessageLogLevel;\n/**\n * Only warning logs\n */\nTools.WarningLogLevel = Logger.WarningLogLevel;\n/**\n * Only error logs\n */\nTools.ErrorLogLevel = Logger.ErrorLogLevel;\n/**\n * All logs\n */\nTools.AllLogLevel = Logger.AllLogLevel;\n/**\n * Checks if the window object exists\n * Back Compat only, please use IsWindowObjectExist instead.\n */\nTools.IsWindowObjectExist = IsWindowObjectExist;\n// Performances\n/**\n * No performance log\n */\nTools.PerformanceNoneLogLevel = 0;\n/**\n * Use user marks to log performance\n */\nTools.PerformanceUserMarkLogLevel = 1;\n/**\n * Log performance to the console\n */\nTools.PerformanceConsoleLogLevel = 2;\n/**\n * Starts a performance counter\n */\nTools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\n/**\n * Ends a specific performance counter\n */\nTools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\n/**\n * Use this className as a decorator on a given class definition to add it a name and optionally its module.\n * You can then use the Tools.getClassName(obj) on an instance to retrieve its class name.\n * This method is the only way to get it done in all cases, even if the .js file declaring the class is minified\n * @param name The name of the class, case should be preserved\n * @param module The name of the Module hosting the class, optional, but strongly recommended to specify if possible. Case should be preserved.\n * @returns a decorator function to apply on the class definition.\n */\nexport function className(name, module) {\n return target => {\n target[\"__bjsclassName__\"] = name;\n target[\"__bjsmoduleName__\"] = module != null ? module : null;\n };\n}\n/**\n * An implementation of a loop for asynchronous functions.\n */\nexport class AsyncLoop {\n /**\n * Constructor.\n * @param iterations the number of iterations.\n * @param func the function to run each iteration\n * @param successCallback the callback that will be called upon successful execution\n * @param offset starting offset.\n */\n constructor(\n /**\n * Defines the number of iterations for the loop\n */\n iterations, func, successCallback, offset = 0) {\n this.iterations = iterations;\n this.index = offset - 1;\n this._done = false;\n this._fn = func;\n this._successCallback = successCallback;\n }\n /**\n * Execute the next iteration. Must be called after the last iteration was finished.\n */\n executeNext() {\n if (!this._done) {\n if (this.index + 1 < this.iterations) {\n ++this.index;\n this._fn(this);\n } else {\n this.breakLoop();\n }\n }\n }\n /**\n * Break the loop and run the success callback.\n */\n breakLoop() {\n this._done = true;\n this._successCallback();\n }\n /**\n * Create and run an async loop.\n * @param iterations the number of iterations.\n * @param fn the function to run each iteration\n * @param successCallback the callback that will be called upon successful execution\n * @param offset starting offset.\n * @returns the created async loop object\n */\n static Run(iterations, fn, successCallback, offset = 0) {\n const loop = new AsyncLoop(iterations, fn, successCallback, offset);\n loop.executeNext();\n return loop;\n }\n /**\n * A for-loop that will run a given number of iterations synchronous and the rest async.\n * @param iterations total number of iterations\n * @param syncedIterations number of synchronous iterations in each async iteration.\n * @param fn the function to call each iteration.\n * @param callback a success call back that will be called when iterating stops.\n * @param breakFunction a break condition (optional)\n * @param timeout timeout settings for the setTimeout function. default - 0.\n * @returns the created async loop object\n */\n static SyncAsyncForLoop(iterations, syncedIterations, fn, callback, breakFunction, timeout = 0) {\n return AsyncLoop.Run(Math.ceil(iterations / syncedIterations), loop => {\n if (breakFunction && breakFunction()) {\n loop.breakLoop();\n } else {\n setTimeout(() => {\n for (let i = 0; i < syncedIterations; ++i) {\n const iteration = loop.index * syncedIterations + i;\n if (iteration >= iterations) {\n break;\n }\n fn(iteration);\n if (breakFunction && breakFunction()) {\n loop.breakLoop();\n break;\n }\n }\n loop.executeNext();\n }, timeout);\n }\n }, callback);\n }\n}\nTools.Mix = Mix;\nTools.IsExponentOfTwo = IsExponentOfTwo;\n// Will only be define if Tools is imported freeing up some space when only engine is required\nEngineStore.FallbackTexture = \"\";","map":{"version":3,"names":["Observable","GetDOMTextContent","IsNavigatorAvailable","IsWindowObjectExist","Logger","DeepCopier","PrecisionDate","_WarnImport","WebRequest","EngineStore","FileToolsOptions","DecodeBase64UrlToBinary","IsBase64DataUrl","LoadFile","FileToolsLoadFile","LoadImage","FileToolLoadImage","ReadFile","FileToolsReadFile","SetCorsBehavior","TimingTools","InstantiationTools","RandomGUID","IsExponentOfTwo","Mix","Tools","BaseUrl","value","CleanUrl","IsAbsoluteUrl","url","indexOf","ScriptBaseUrl","ScriptPreprocessUrl","func","DefaultRetryStrategy","strategy","CorsBehavior","UseFallbackTexture","RegisteredExternalClasses","classes","fallbackTexture","FallbackTexture","FetchToRef","u","v","width","height","pixels","color","wrappedU","Math","abs","wrappedV","position","r","g","b","a","alpha","Instantiate","className","SetImmediate","action","FloatRound","fround","GetFilename","path","index","lastIndexOf","substring","GetFolderPath","uri","returnUnchangedIfNoSlash","ToDegrees","angle","PI","ToRadians","SmoothAngleChange","previousAngle","newAngle","smoothFactor","previousAngleRad","newAngleRad","atan2","sin","cos","MakeArray","obj","allowsNullUndefined","undefined","Array","isArray","GetPointerPrefix","engine","window","PointerEvent","element","SetReferrerPolicyBehavior","referrerPolicy","PreprocessUrl","processor","input","onLoad","onError","offlineProvider","mimeType","imageBitmapOptions","onSuccess","onProgress","useArrayBuffer","LoadFileAsync","Promise","resolve","reject","data","request","exception","GetBabylonScriptURL","scriptUrl","forceAbsoluteUrl","startsWith","_DefaultCdnUrl","baseUrl","length","replace","GetAbsoluteUrl","LoadBabylonScript","scriptId","LoadScript","LoadBabylonScriptAsync","LoadScriptAsync","useModule","importScripts","e","head","document","getElementsByTagName","script","createElement","setAttribute","innerText","id","onload","onerror","appendChild","message","Error","ReadFileAsDataURL","fileToLoad","callback","progressCallback","reader","FileReader","onCompleteObservable","abort","onloadend","notifyObservers","target","onprogress","readAsDataURL","file","FileAsURL","content","fileBlob","Blob","URL","link","createObjectURL","Format","decimals","toFixed","DeepCopy","source","destination","doNotCopyList","mustCopyList","IsEmpty","i","Object","prototype","hasOwnProperty","call","RegisterTopRootEvents","windowElement","events","event","addEventListener","name","handler","parent","UnregisterTopRootEvents","removeEventListener","DumpFramebuffer","successCallback","fileName","quality","_asyncToGenerator","DumpData","invertY","toArrayBuffer","DumpDataAsync","_IsOffScreenCanvas","canvas","convertToBlob","ToBlob","toBlob","type","setTimeout","binStr","atob","toDataURL","split","len","arr","Uint8Array","charCodeAt","then","blob","DownloadBlob","date","Date","stringDate","getFullYear","getMonth","slice","getDate","getHours","getMinutes","Download","newWindow","open","img","revokeObjectURL","src","body","EncodeScreenshotCanvasData","base64data","result","base64Image","style","display","href","download","parentElement","removeChild","click","BackCompatCameraNoPreventDefault","args","CreateScreenshot","camera","size","forceDownload","CreateScreenshotAsync","CreateScreenshotUsingRenderTarget","samples","antialiasing","renderSprites","enableStencilBuffer","useLayerMask","customizeTexture","CreateScreenshotUsingRenderTargetAsync","RandomId","IsBase64","DecodeBase64","errorsCount","Log","Warn","LogCache","ClearLogCache","LogLevels","level","PerformanceLogLevel","PerformanceUserMarkLogLevel","StartPerformanceCounter","_StartUserMark","EndPerformanceCounter","_EndUserMark","PerformanceConsoleLogLevel","_StartPerformanceConsole","_EndPerformanceConsole","_StartPerformanceCounterDisabled","_EndPerformanceCounterDisabled","counterName","condition","_Performance","performance","mark","measure","console","time","timeEnd","Now","GetClassName","object","isType","getClassName","classObj","getPrototypeOf","constructor","First","array","predicate","el","getFullClassName","moduleName","DelayAsync","delay","IsSafari","test","navigator","userAgent","UseCustomRequestHeaders","CustomRequestHeaders","location","origin","NoneLogLevel","MessageLogLevel","WarningLogLevel","ErrorLogLevel","AllLogLevel","PerformanceNoneLogLevel","module","AsyncLoop","iterations","offset","_done","_fn","_successCallback","executeNext","breakLoop","Run","fn","loop","SyncAsyncForLoop","syncedIterations","breakFunction","timeout","ceil","iteration"],"sources":["F:/workspace/202226701027/huinongbao-app/node_modules/@babylonjs/core/Misc/tools.js"],"sourcesContent":["import { Observable } from \"./observable.js\";\nimport { GetDOMTextContent, IsNavigatorAvailable, IsWindowObjectExist } from \"./domManagement.js\";\nimport { Logger } from \"./logger.js\";\nimport { DeepCopier } from \"./deepCopier.js\";\nimport { PrecisionDate } from \"./precisionDate.js\";\nimport { _WarnImport } from \"./devTools.js\";\nimport { WebRequest } from \"./webRequest.js\";\nimport { EngineStore } from \"../Engines/engineStore.js\";\nimport { FileToolsOptions, DecodeBase64UrlToBinary, IsBase64DataUrl, LoadFile as FileToolsLoadFile, LoadImage as FileToolLoadImage, ReadFile as FileToolsReadFile, SetCorsBehavior, } from \"./fileTools.js\";\nimport { TimingTools } from \"./timingTools.js\";\nimport { InstantiationTools } from \"./instantiationTools.js\";\nimport { RandomGUID } from \"./guid.js\";\nimport { IsExponentOfTwo, Mix } from \"./tools.functions.js\";\n/**\n * Class containing a set of static utilities functions\n */\nexport class Tools {\n /**\n * Gets or sets the base URL to use to load assets\n */\n static get BaseUrl() {\n return FileToolsOptions.BaseUrl;\n }\n static set BaseUrl(value) {\n FileToolsOptions.BaseUrl = value;\n }\n /**\n * Gets or sets the clean URL function to use to load assets\n */\n static get CleanUrl() {\n return FileToolsOptions.CleanUrl;\n }\n static set CleanUrl(value) {\n FileToolsOptions.CleanUrl = value;\n }\n /**\n * This function checks whether a URL is absolute or not.\n * It will also detect data and blob URLs\n * @param url the url to check\n * @returns is the url absolute or relative\n */\n static IsAbsoluteUrl(url) {\n // See https://stackoverflow.com/a/38979205.\n // URL is protocol-relative (= absolute)\n if (url.indexOf(\"//\") === 0) {\n return true;\n }\n // URL has no protocol (= relative)\n if (url.indexOf(\"://\") === -1) {\n return false;\n }\n // URL does not contain a dot, i.e. no TLD (= relative, possibly REST)\n if (url.indexOf(\".\") === -1) {\n return false;\n }\n // URL does not contain a single slash (= relative)\n if (url.indexOf(\"/\") === -1) {\n return false;\n }\n // The first colon comes after the first slash (= relative)\n if (url.indexOf(\":\") > url.indexOf(\"/\")) {\n return false;\n }\n // Protocol is defined before first dot (= absolute)\n if (url.indexOf(\"://\") < url.indexOf(\".\")) {\n return true;\n }\n if (url.indexOf(\"data:\") === 0 || url.indexOf(\"blob:\") === 0) {\n return true;\n }\n // Anything else must be relative\n return false;\n }\n /**\n * Sets the base URL to use to load scripts\n */\n static set ScriptBaseUrl(value) {\n FileToolsOptions.ScriptBaseUrl = value;\n }\n static get ScriptBaseUrl() {\n return FileToolsOptions.ScriptBaseUrl;\n }\n /**\n * Sets a preprocessing function to run on a source URL before importing it\n * Note that this function will execute AFTER the base URL is appended to the URL\n */\n static set ScriptPreprocessUrl(func) {\n FileToolsOptions.ScriptPreprocessUrl = func;\n }\n static get ScriptPreprocessUrl() {\n return FileToolsOptions.ScriptPreprocessUrl;\n }\n /**\n * Gets or sets the retry strategy to apply when an error happens while loading an asset\n */\n static get DefaultRetryStrategy() {\n return FileToolsOptions.DefaultRetryStrategy;\n }\n static set DefaultRetryStrategy(strategy) {\n FileToolsOptions.DefaultRetryStrategy = strategy;\n }\n /**\n * Default behavior for cors in the application.\n * It can be a string if the expected behavior is identical in the entire app.\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)\n */\n static get CorsBehavior() {\n return FileToolsOptions.CorsBehavior;\n }\n static set CorsBehavior(value) {\n FileToolsOptions.CorsBehavior = value;\n }\n /**\n * Gets or sets a global variable indicating if fallback texture must be used when a texture cannot be loaded\n * @ignorenaming\n */\n static get UseFallbackTexture() {\n return EngineStore.UseFallbackTexture;\n }\n static set UseFallbackTexture(value) {\n EngineStore.UseFallbackTexture = value;\n }\n /**\n * Use this object to register external classes like custom textures or material\n * to allow the loaders to instantiate them\n */\n static get RegisteredExternalClasses() {\n return InstantiationTools.RegisteredExternalClasses;\n }\n static set RegisteredExternalClasses(classes) {\n InstantiationTools.RegisteredExternalClasses = classes;\n }\n /**\n * Texture content used if a texture cannot loaded\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static get fallbackTexture() {\n return EngineStore.FallbackTexture;\n }\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static set fallbackTexture(value) {\n EngineStore.FallbackTexture = value;\n }\n /**\n * Read the content of a byte array at a specified coordinates (taking in account wrapping)\n * @param u defines the coordinate on X axis\n * @param v defines the coordinate on Y axis\n * @param width defines the width of the source data\n * @param height defines the height of the source data\n * @param pixels defines the source byte array\n * @param color defines the output color\n */\n static FetchToRef(u, v, width, height, pixels, color) {\n const wrappedU = (Math.abs(u) * width) % width | 0;\n const wrappedV = (Math.abs(v) * height) % height | 0;\n const position = (wrappedU + wrappedV * width) * 4;\n color.r = pixels[position] / 255;\n color.g = pixels[position + 1] / 255;\n color.b = pixels[position + 2] / 255;\n color.a = pixels[position + 3] / 255;\n }\n /**\n * Interpolates between a and b via alpha\n * @param a The lower value (returned when alpha = 0)\n * @param b The upper value (returned when alpha = 1)\n * @param alpha The interpolation-factor\n * @returns The mixed value\n */\n static Mix(a, b, alpha) {\n return 0;\n }\n /**\n * Tries to instantiate a new object from a given class name\n * @param className defines the class name to instantiate\n * @returns the new object or null if the system was not able to do the instantiation\n */\n static Instantiate(className) {\n return InstantiationTools.Instantiate(className);\n }\n /**\n * Polyfill for setImmediate\n * @param action defines the action to execute after the current execution block\n */\n static SetImmediate(action) {\n TimingTools.SetImmediate(action);\n }\n /**\n * Function indicating if a number is an exponent of 2\n * @param value defines the value to test\n * @returns true if the value is an exponent of 2\n */\n static IsExponentOfTwo(value) {\n return true;\n }\n /**\n * Returns the nearest 32-bit single precision float representation of a Number\n * @param value A Number. If the parameter is of a different type, it will get converted\n * to a number or to NaN if it cannot be converted\n * @returns number\n */\n static FloatRound(value) {\n return Math.fround(value);\n }\n /**\n * Extracts the filename from a path\n * @param path defines the path to use\n * @returns the filename\n */\n static GetFilename(path) {\n const index = path.lastIndexOf(\"/\");\n if (index < 0) {\n return path;\n }\n return path.substring(index + 1);\n }\n /**\n * Extracts the \"folder\" part of a path (everything before the filename).\n * @param uri The URI to extract the info from\n * @param returnUnchangedIfNoSlash Do not touch the URI if no slashes are present\n * @returns The \"folder\" part of the path\n */\n static GetFolderPath(uri, returnUnchangedIfNoSlash = false) {\n const index = uri.lastIndexOf(\"/\");\n if (index < 0) {\n if (returnUnchangedIfNoSlash) {\n return uri;\n }\n return \"\";\n }\n return uri.substring(0, index + 1);\n }\n /**\n * Convert an angle in radians to degrees\n * @param angle defines the angle to convert\n * @returns the angle in degrees\n */\n static ToDegrees(angle) {\n return (angle * 180) / Math.PI;\n }\n /**\n * Convert an angle in degrees to radians\n * @param angle defines the angle to convert\n * @returns the angle in radians\n */\n static ToRadians(angle) {\n return (angle * Math.PI) / 180;\n }\n /**\n * Smooth angle changes (kind of low-pass filter), in particular for device orientation \"shaking\"\n * Use trigonometric functions to avoid discontinuity (0/360, -180/180)\n * @param previousAngle defines last angle value, in degrees\n * @param newAngle defines new angle value, in degrees\n * @param smoothFactor defines smoothing sensitivity; min 0: no smoothing, max 1: new data ignored\n * @returns the angle in degrees\n */\n static SmoothAngleChange(previousAngle, newAngle, smoothFactor = 0.9) {\n const previousAngleRad = this.ToRadians(previousAngle);\n const newAngleRad = this.ToRadians(newAngle);\n return this.ToDegrees(Math.atan2((1 - smoothFactor) * Math.sin(newAngleRad) + smoothFactor * Math.sin(previousAngleRad), (1 - smoothFactor) * Math.cos(newAngleRad) + smoothFactor * Math.cos(previousAngleRad)));\n }\n /**\n * Returns an array if obj is not an array\n * @param obj defines the object to evaluate as an array\n * @param allowsNullUndefined defines a boolean indicating if obj is allowed to be null or undefined\n * @returns either obj directly if obj is an array or a new array containing obj\n */\n static MakeArray(obj, allowsNullUndefined) {\n if (allowsNullUndefined !== true && (obj === undefined || obj == null)) {\n return null;\n }\n return Array.isArray(obj) ? obj : [obj];\n }\n /**\n * Gets the pointer prefix to use\n * @param engine defines the engine we are finding the prefix for\n * @returns \"pointer\" if touch is enabled. Else returns \"mouse\"\n */\n static GetPointerPrefix(engine) {\n return IsWindowObjectExist() && !window.PointerEvent ? \"mouse\" : \"pointer\";\n }\n /**\n * Sets the cors behavior on a dom element. This will add the required Tools.CorsBehavior to the element.\n * @param url define the url we are trying\n * @param element define the dom element where to configure the cors policy\n * @param element.crossOrigin\n */\n static SetCorsBehavior(url, element) {\n SetCorsBehavior(url, element);\n }\n /**\n * Sets the referrerPolicy behavior on a dom element.\n * @param referrerPolicy define the referrer policy to use\n * @param element define the dom element where to configure the referrer policy\n * @param element.referrerPolicy\n */\n static SetReferrerPolicyBehavior(referrerPolicy, element) {\n element.referrerPolicy = referrerPolicy;\n }\n // External files\n /**\n * Gets or sets a function used to pre-process url before using them to load assets\n */\n static get PreprocessUrl() {\n return FileToolsOptions.PreprocessUrl;\n }\n static set PreprocessUrl(processor) {\n FileToolsOptions.PreprocessUrl = processor;\n }\n /**\n * Loads an image as an HTMLImageElement.\n * @param input url string, ArrayBuffer, or Blob to load\n * @param onLoad callback called when the image successfully loads\n * @param onError callback called when the image fails to load\n * @param offlineProvider offline provider for caching\n * @param mimeType optional mime type\n * @param imageBitmapOptions optional the options to use when creating an ImageBitmap\n * @returns the HTMLImageElement of the loaded image\n */\n static LoadImage(input, onLoad, onError, offlineProvider, mimeType, imageBitmapOptions) {\n return FileToolLoadImage(input, onLoad, onError, offlineProvider, mimeType, imageBitmapOptions);\n }\n /**\n * Loads a file from a url\n * @param url url string, ArrayBuffer, or Blob to load\n * @param onSuccess callback called when the file successfully loads\n * @param onProgress callback called while file is loading (if the server supports this mode)\n * @param offlineProvider defines the offline provider for caching\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\n * @param onError callback called when the file fails to load\n * @returns a file request object\n */\n static LoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError) {\n return FileToolsLoadFile(url, onSuccess, onProgress, offlineProvider, useArrayBuffer, onError);\n }\n /**\n * Loads a file from a url\n * @param url the file url to load\n * @param useArrayBuffer defines a boolean indicating that date must be returned as ArrayBuffer\n * @returns a promise containing an ArrayBuffer corresponding to the loaded file\n */\n static LoadFileAsync(url, useArrayBuffer = true) {\n return new Promise((resolve, reject) => {\n FileToolsLoadFile(url, (data) => {\n resolve(data);\n }, undefined, undefined, useArrayBuffer, (request, exception) => {\n reject(exception);\n });\n });\n }\n /**\n * Get a script URL including preprocessing\n * @param scriptUrl the script Url to process\n * @param forceAbsoluteUrl force the script to be an absolute url (adding the current base url if necessary)\n * @returns a modified URL to use\n */\n static GetBabylonScriptURL(scriptUrl, forceAbsoluteUrl) {\n if (!scriptUrl) {\n return \"\";\n }\n // if the base URL was set, and the script Url is an absolute path change the default path\n if (Tools.ScriptBaseUrl && scriptUrl.startsWith(Tools._DefaultCdnUrl)) {\n // change the default host, which is https://cdn.babylonjs.com with the one defined\n // make sure no trailing slash is present\n const baseUrl = Tools.ScriptBaseUrl[Tools.ScriptBaseUrl.length - 1] === \"/\" ? Tools.ScriptBaseUrl.substring(0, Tools.ScriptBaseUrl.length - 1) : Tools.ScriptBaseUrl;\n scriptUrl = scriptUrl.replace(Tools._DefaultCdnUrl, baseUrl);\n }\n // run the preprocessor\n scriptUrl = Tools.ScriptPreprocessUrl(scriptUrl);\n if (forceAbsoluteUrl) {\n scriptUrl = Tools.GetAbsoluteUrl(scriptUrl);\n }\n return scriptUrl;\n }\n /**\n * This function is used internally by babylon components to load a script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param onSuccess defines the callback called when the script is loaded\n * @param onError defines the callback to call if an error occurs\n * @param scriptId defines the id of the script element\n */\n static LoadBabylonScript(scriptUrl, onSuccess, onError, scriptId) {\n scriptUrl = Tools.GetBabylonScriptURL(scriptUrl);\n Tools.LoadScript(scriptUrl, onSuccess, onError);\n }\n /**\n * Load an asynchronous script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to laod\n * @returns a promise request object\n */\n static LoadBabylonScriptAsync(scriptUrl) {\n scriptUrl = Tools.GetBabylonScriptURL(scriptUrl);\n return Tools.LoadScriptAsync(scriptUrl);\n }\n /**\n * This function is used internally by babylon components to load a script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param onSuccess defines the callback called when the script is loaded\n * @param onError defines the callback to call if an error occurs\n * @param scriptId defines the id of the script element\n * @param useModule defines if we should use the module strategy to load the script\n */\n static LoadScript(scriptUrl, onSuccess, onError, scriptId, useModule = false) {\n if (typeof importScripts === \"function\") {\n try {\n importScripts(scriptUrl);\n if (onSuccess) {\n onSuccess();\n }\n }\n catch (e) {\n onError?.(`Unable to load script '${scriptUrl}' in worker`, e);\n }\n return;\n }\n else if (!IsWindowObjectExist()) {\n onError?.(`Cannot load script '${scriptUrl}' outside of a window or a worker`);\n return;\n }\n const head = document.getElementsByTagName(\"head\")[0];\n const script = document.createElement(\"script\");\n if (useModule) {\n script.setAttribute(\"type\", \"module\");\n script.innerText = scriptUrl;\n }\n else {\n script.setAttribute(\"type\", \"text/javascript\");\n script.setAttribute(\"src\", scriptUrl);\n }\n if (scriptId) {\n script.id = scriptId;\n }\n script.onload = () => {\n if (onSuccess) {\n onSuccess();\n }\n };\n script.onerror = (e) => {\n if (onError) {\n onError(`Unable to load script '${scriptUrl}'`, e);\n }\n };\n head.appendChild(script);\n }\n /**\n * Load an asynchronous script (identified by an url). When the url returns, the\n * content of this file is added into a new script element, attached to the DOM (body element)\n * @param scriptUrl defines the url of the script to load\n * @param scriptId defines the id of the script element\n * @returns a promise request object\n */\n static LoadScriptAsync(scriptUrl, scriptId) {\n return new Promise((resolve, reject) => {\n this.LoadScript(scriptUrl, () => {\n resolve();\n }, (message, exception) => {\n reject(exception || new Error(message));\n }, scriptId);\n });\n }\n /**\n * Loads a file from a blob\n * @param fileToLoad defines the blob to use\n * @param callback defines the callback to call when data is loaded\n * @param progressCallback defines the callback to call during loading process\n * @returns a file request object\n */\n static ReadFileAsDataURL(fileToLoad, callback, progressCallback) {\n const reader = new FileReader();\n const request = {\n onCompleteObservable: new Observable(),\n abort: () => reader.abort(),\n };\n reader.onloadend = () => {\n request.onCompleteObservable.notifyObservers(request);\n };\n reader.onload = (e) => {\n //target doesn't have result from ts 1.3\n callback(e.target[\"result\"]);\n };\n reader.onprogress = progressCallback;\n reader.readAsDataURL(fileToLoad);\n return request;\n }\n /**\n * Reads a file from a File object\n * @param file defines the file to load\n * @param onSuccess defines the callback to call when data is loaded\n * @param onProgress defines the callback to call during loading process\n * @param useArrayBuffer defines a boolean indicating that data must be returned as an ArrayBuffer\n * @param onError defines the callback to call when an error occurs\n * @returns a file request object\n */\n static ReadFile(file, onSuccess, onProgress, useArrayBuffer, onError) {\n return FileToolsReadFile(file, onSuccess, onProgress, useArrayBuffer, onError);\n }\n /**\n * Creates a data url from a given string content\n * @param content defines the content to convert\n * @returns the new data url link\n */\n static FileAsURL(content) {\n const fileBlob = new Blob([content]);\n const url = window.URL;\n const link = url.createObjectURL(fileBlob);\n return link;\n }\n /**\n * Format the given number to a specific decimal format\n * @param value defines the number to format\n * @param decimals defines the number of decimals to use\n * @returns the formatted string\n */\n static Format(value, decimals = 2) {\n return value.toFixed(decimals);\n }\n /**\n * Tries to copy an object by duplicating every property\n * @param source defines the source object\n * @param destination defines the target object\n * @param doNotCopyList defines a list of properties to avoid\n * @param mustCopyList defines a list of properties to copy (even if they start with _)\n */\n static DeepCopy(source, destination, doNotCopyList, mustCopyList) {\n DeepCopier.DeepCopy(source, destination, doNotCopyList, mustCopyList);\n }\n /**\n * Gets a boolean indicating if the given object has no own property\n * @param obj defines the object to test\n * @returns true if object has no own property\n */\n static IsEmpty(obj) {\n for (const i in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, i)) {\n return false;\n }\n }\n return true;\n }\n /**\n * Function used to register events at window level\n * @param windowElement defines the Window object to use\n * @param events defines the events to register\n */\n static RegisterTopRootEvents(windowElement, events) {\n for (let index = 0; index < events.length; index++) {\n const event = events[index];\n windowElement.addEventListener(event.name, event.handler, false);\n try {\n if (window.parent) {\n window.parent.addEventListener(event.name, event.handler, false);\n }\n }\n catch (e) {\n // Silently fails...\n }\n }\n }\n /**\n * Function used to unregister events from window level\n * @param windowElement defines the Window object to use\n * @param events defines the events to unregister\n */\n static UnregisterTopRootEvents(windowElement, events) {\n for (let index = 0; index < events.length; index++) {\n const event = events[index];\n windowElement.removeEventListener(event.name, event.handler);\n try {\n if (windowElement.parent) {\n windowElement.parent.removeEventListener(event.name, event.handler);\n }\n }\n catch (e) {\n // Silently fails...\n }\n }\n }\n /**\n * Dumps the current bound framebuffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param engine defines the hosting engine\n * @param successCallback defines the callback triggered once the data are available\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns a void promise\n */\n static async DumpFramebuffer(width, height, engine, successCallback, mimeType = \"image/png\", fileName, quality) {\n throw _WarnImport(\"DumpTools\");\n }\n /**\n * Dumps an array buffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param data the data array\n * @param successCallback defines the callback triggered once the data are available\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param invertY true to invert the picture in the Y dimension\n * @param toArrayBuffer true to convert the data to an ArrayBuffer (encoded as `mimeType`) instead of a base64 string\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static DumpData(width, height, data, successCallback, mimeType = \"image/png\", fileName, invertY = false, toArrayBuffer = false, quality) {\n throw _WarnImport(\"DumpTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Dumps an array buffer\n * @param width defines the rendering width\n * @param height defines the rendering height\n * @param data the data array\n * @param mimeType defines the mime type of the result\n * @param fileName defines the filename to download. If present, the result will automatically be downloaded\n * @param invertY true to invert the picture in the Y dimension\n * @param toArrayBuffer true to convert the data to an ArrayBuffer (encoded as `mimeType`) instead of a base64 string\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns a promise that resolve to the final data\n */\n static DumpDataAsync(width, height, data, mimeType = \"image/png\", fileName, invertY = false, toArrayBuffer = false, quality) {\n throw _WarnImport(\"DumpTools\");\n }\n static _IsOffScreenCanvas(canvas) {\n return canvas.convertToBlob !== undefined;\n }\n /**\n * Converts the canvas data to blob.\n * This acts as a polyfill for browsers not supporting the to blob function.\n * @param canvas Defines the canvas to extract the data from (can be an offscreen canvas)\n * @param successCallback Defines the callback triggered once the data are available\n * @param mimeType Defines the mime type of the result\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static ToBlob(canvas, successCallback, mimeType = \"image/png\", quality) {\n // We need HTMLCanvasElement.toBlob for HD screenshots\n if (!Tools._IsOffScreenCanvas(canvas) && !canvas.toBlob) {\n // low performance polyfill based on toDataURL (https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob)\n canvas.toBlob = function (callback, type, quality) {\n setTimeout(() => {\n const binStr = atob(this.toDataURL(type, quality).split(\",\")[1]), len = binStr.length, arr = new Uint8Array(len);\n for (let i = 0; i < len; i++) {\n arr[i] = binStr.charCodeAt(i);\n }\n callback(new Blob([arr]));\n });\n };\n }\n if (Tools._IsOffScreenCanvas(canvas)) {\n canvas\n .convertToBlob({\n type: mimeType,\n quality,\n })\n .then((blob) => successCallback(blob));\n }\n else {\n canvas.toBlob(function (blob) {\n successCallback(blob);\n }, mimeType, quality);\n }\n }\n /**\n * Download a Blob object\n * @param blob the Blob object\n * @param fileName the file name to download\n */\n static DownloadBlob(blob, fileName) {\n //Creating a link if the browser have the download attribute on the a tag, to automatically start download generated image.\n if (\"download\" in document.createElement(\"a\")) {\n if (!fileName) {\n const date = new Date();\n const stringDate = (date.getFullYear() + \"-\" + (date.getMonth() + 1)).slice(2) + \"-\" + date.getDate() + \"_\" + date.getHours() + \"-\" + (\"0\" + date.getMinutes()).slice(-2);\n fileName = \"screenshot_\" + stringDate + \".png\";\n }\n Tools.Download(blob, fileName);\n }\n else {\n if (blob && typeof URL !== \"undefined\") {\n const url = URL.createObjectURL(blob);\n const newWindow = window.open(\"\");\n if (!newWindow) {\n return;\n }\n const img = newWindow.document.createElement(\"img\");\n img.onload = function () {\n // no longer need to read the blob so it's revoked\n URL.revokeObjectURL(url);\n };\n img.src = url;\n newWindow.document.body.appendChild(img);\n }\n }\n }\n /**\n * Encodes the canvas data to base 64, or automatically downloads the result if `fileName` is defined.\n * @param canvas The canvas to get the data from, which can be an offscreen canvas.\n * @param successCallback The callback which is triggered once the data is available. If `fileName` is defined, the callback will be invoked after the download occurs, and the `data` argument will be an empty string.\n * @param mimeType The mime type of the result.\n * @param fileName The name of the file to download. If defined, the result will automatically be downloaded. If not defined, and `successCallback` is also not defined, the result will automatically be downloaded with an auto-generated file name.\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n static EncodeScreenshotCanvasData(canvas, successCallback, mimeType = \"image/png\", fileName, quality) {\n if (typeof fileName === \"string\" || !successCallback) {\n this.ToBlob(canvas, function (blob) {\n if (blob) {\n Tools.DownloadBlob(blob, fileName);\n }\n if (successCallback) {\n successCallback(\"\");\n }\n }, mimeType, quality);\n }\n else if (successCallback) {\n if (Tools._IsOffScreenCanvas(canvas)) {\n canvas\n .convertToBlob({\n type: mimeType,\n quality,\n })\n .then((blob) => {\n const reader = new FileReader();\n reader.readAsDataURL(blob);\n reader.onloadend = () => {\n const base64data = reader.result;\n successCallback(base64data);\n };\n });\n return;\n }\n const base64Image = canvas.toDataURL(mimeType, quality);\n successCallback(base64Image);\n }\n }\n /**\n * Downloads a blob in the browser\n * @param blob defines the blob to download\n * @param fileName defines the name of the downloaded file\n */\n static Download(blob, fileName) {\n if (typeof URL === \"undefined\") {\n return;\n }\n const url = window.URL.createObjectURL(blob);\n const a = document.createElement(\"a\");\n document.body.appendChild(a);\n a.style.display = \"none\";\n a.href = url;\n a.download = fileName;\n a.addEventListener(\"click\", () => {\n if (a.parentElement) {\n a.parentElement.removeChild(a);\n }\n });\n a.click();\n window.URL.revokeObjectURL(url);\n }\n /**\n * Will return the right value of the noPreventDefault variable\n * Needed to keep backwards compatibility to the old API.\n *\n * @param args arguments passed to the attachControl function\n * @returns the correct value for noPreventDefault\n */\n static BackCompatCameraNoPreventDefault(args) {\n // is it used correctly?\n if (typeof args[0] === \"boolean\") {\n return args[0];\n }\n else if (typeof args[1] === \"boolean\") {\n return args[1];\n }\n return false;\n }\n /**\n * Captures a screenshot of the current rendering\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine defines the rendering engine\n * @param camera defines the source camera\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param successCallback defines the callback receives a single parameter which contains the\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\n * src parameter of an to display it\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param forceDownload force the system to download the image even if a successCallback is provided\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshot(engine, camera, size, successCallback, mimeType = \"image/png\", forceDownload = false, quality) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Captures a screenshot of the current rendering\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine defines the rendering engine\n * @param camera defines the source camera\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param mimeType defines the MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\n * to the src parameter of an to display it\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotAsync(engine, camera, size, mimeType = \"image/png\", quality) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n /**\n * Generates an image screenshot from the specified camera.\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine The engine to use for rendering\n * @param camera The camera to use for rendering\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param successCallback The callback receives a single parameter which contains the\n * screenshot as a string of base64-encoded characters. This string can be assigned to the\n * src parameter of an to display it\n * @param mimeType The MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param samples Texture samples (default: 1)\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\n * @param fileName A name for for the downloaded file.\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\n * @param enableStencilBuffer Whether the stencil buffer should be enabled or not (default: false)\n * @param useLayerMask if the camera's layer mask should be used to filter what should be rendered (default: true)\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @param customizeTexture An optional callback that can be used to modify the render target texture before taking the screenshot. This can be used, for instance, to enable camera post-processes before taking the screenshot.\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotUsingRenderTarget(engine, camera, size, successCallback, mimeType = \"image/png\", samples = 1, antialiasing = false, fileName, renderSprites = false, enableStencilBuffer = false, useLayerMask = true, quality, customizeTexture) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n // eslint-disable-next-line jsdoc/require-returns-check\n /**\n * Generates an image screenshot from the specified camera.\n * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/renderToPNG\n * @param engine The engine to use for rendering\n * @param camera The camera to use for rendering\n * @param size This parameter can be set to a single number or to an object with the\n * following (optional) properties: precision, width, height. If a single number is passed,\n * it will be used for both width and height. If an object is passed, the screenshot size\n * will be derived from the parameters. The precision property is a multiplier allowing\n * rendering at a higher or lower resolution\n * @param mimeType The MIME type of the screenshot image (default: image/png).\n * Check your browser for supported MIME types\n * @param samples Texture samples (default: 1)\n * @param antialiasing Whether antialiasing should be turned on or not (default: false)\n * @param fileName A name for for the downloaded file.\n * @param renderSprites Whether the sprites should be rendered or not (default: false)\n * @param enableStencilBuffer Whether the stencil buffer should be enabled or not (default: false)\n * @param useLayerMask if the camera's layer mask should be used to filter what should be rendered (default: true)\n * @param quality The quality of the image if lossy mimeType is used (e.g. image/jpeg, image/webp). See {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob | HTMLCanvasElement.toBlob()}'s `quality` parameter.\n * @param customizeTexture An optional callback that can be used to modify the render target texture before taking the screenshot. This can be used, for instance, to enable camera post-processes before taking the screenshot.\n * @returns screenshot as a string of base64-encoded characters. This string can be assigned\n * to the src parameter of an to display it\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static CreateScreenshotUsingRenderTargetAsync(engine, camera, size, mimeType = \"image/png\", samples = 1, antialiasing = false, fileName, renderSprites = false, enableStencilBuffer = false, useLayerMask = true, quality, customizeTexture) {\n throw _WarnImport(\"ScreenshotTools\");\n }\n /**\n * Implementation from http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#answer-2117523\n * Be aware Math.random() could cause collisions, but:\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\"\n * @returns a pseudo random id\n */\n static RandomId() {\n return RandomGUID();\n }\n /**\n * Test if the given uri is a base64 string\n * @deprecated Please use FileTools.IsBase64DataUrl instead.\n * @param uri The uri to test\n * @returns True if the uri is a base64 string or false otherwise\n */\n static IsBase64(uri) {\n return IsBase64DataUrl(uri);\n }\n /**\n * Decode the given base64 uri.\n * @deprecated Please use FileTools.DecodeBase64UrlToBinary instead.\n * @param uri The uri to decode\n * @returns The decoded base64 data.\n */\n static DecodeBase64(uri) {\n return DecodeBase64UrlToBinary(uri);\n }\n /**\n * Gets a value indicating the number of loading errors\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static get errorsCount() {\n return Logger.errorsCount;\n }\n /**\n * Log a message to the console\n * @param message defines the message to log\n */\n static Log(message) {\n Logger.Log(message);\n }\n /**\n * Write a warning message to the console\n * @param message defines the message to log\n */\n static Warn(message) {\n Logger.Warn(message);\n }\n /**\n * Write an error message to the console\n * @param message defines the message to log\n */\n static Error(message) {\n Logger.Error(message);\n }\n /**\n * Gets current log cache (list of logs)\n */\n static get LogCache() {\n return Logger.LogCache;\n }\n /**\n * Clears the log cache\n */\n static ClearLogCache() {\n Logger.ClearLogCache();\n }\n /**\n * Sets the current log level (MessageLogLevel / WarningLogLevel / ErrorLogLevel)\n */\n static set LogLevels(level) {\n Logger.LogLevels = level;\n }\n /**\n * Sets the current performance log level\n */\n static set PerformanceLogLevel(level) {\n if ((level & Tools.PerformanceUserMarkLogLevel) === Tools.PerformanceUserMarkLogLevel) {\n Tools.StartPerformanceCounter = Tools._StartUserMark;\n Tools.EndPerformanceCounter = Tools._EndUserMark;\n return;\n }\n if ((level & Tools.PerformanceConsoleLogLevel) === Tools.PerformanceConsoleLogLevel) {\n Tools.StartPerformanceCounter = Tools._StartPerformanceConsole;\n Tools.EndPerformanceCounter = Tools._EndPerformanceConsole;\n return;\n }\n Tools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\n Tools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static _StartPerformanceCounterDisabled(counterName, condition) { }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static _EndPerformanceCounterDisabled(counterName, condition) { }\n static _StartUserMark(counterName, condition = true) {\n if (!Tools._Performance) {\n if (!IsWindowObjectExist()) {\n return;\n }\n Tools._Performance = window.performance;\n }\n if (!condition || !Tools._Performance.mark) {\n return;\n }\n Tools._Performance.mark(counterName + \"-Begin\");\n }\n static _EndUserMark(counterName, condition = true) {\n if (!condition || !Tools._Performance.mark) {\n return;\n }\n Tools._Performance.mark(counterName + \"-End\");\n Tools._Performance.measure(counterName, counterName + \"-Begin\", counterName + \"-End\");\n }\n static _StartPerformanceConsole(counterName, condition = true) {\n if (!condition) {\n return;\n }\n Tools._StartUserMark(counterName, condition);\n if (console.time) {\n console.time(counterName);\n }\n }\n static _EndPerformanceConsole(counterName, condition = true) {\n if (!condition) {\n return;\n }\n Tools._EndUserMark(counterName, condition);\n console.timeEnd(counterName);\n }\n /**\n * Gets either window.performance.now() if supported or Date.now() else\n */\n static get Now() {\n return PrecisionDate.Now;\n }\n /**\n * This method will return the name of the class used to create the instance of the given object.\n * It will works only on Javascript basic data types (number, string, ...) and instance of class declared with the @className decorator.\n * @param object the object to get the class name from\n * @param isType defines if the object is actually a type\n * @returns the name of the class, will be \"object\" for a custom data type not using the @className decorator\n */\n static GetClassName(object, isType = false) {\n let name = null;\n if (!isType && object.getClassName) {\n name = object.getClassName();\n }\n else {\n if (object instanceof Object) {\n const classObj = isType ? object : Object.getPrototypeOf(object);\n name = classObj.constructor[\"__bjsclassName__\"];\n }\n if (!name) {\n name = typeof object;\n }\n }\n return name;\n }\n /**\n * Gets the first element of an array satisfying a given predicate\n * @param array defines the array to browse\n * @param predicate defines the predicate to use\n * @returns null if not found or the element\n */\n static First(array, predicate) {\n for (const el of array) {\n if (predicate(el)) {\n return el;\n }\n }\n return null;\n }\n /**\n * This method will return the name of the full name of the class, including its owning module (if any).\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).\n * @param object the object to get the class name from\n * @param isType defines if the object is actually a type\n * @returns 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.\n * @ignorenaming\n */\n // eslint-disable-next-line @typescript-eslint/naming-convention\n static getFullClassName(object, isType = false) {\n let className = null;\n let moduleName = null;\n if (!isType && object.getClassName) {\n className = object.getClassName();\n }\n else {\n if (object instanceof Object) {\n const classObj = isType ? object : Object.getPrototypeOf(object);\n className = classObj.constructor[\"__bjsclassName__\"];\n moduleName = classObj.constructor[\"__bjsmoduleName__\"];\n }\n if (!className) {\n className = typeof object;\n }\n }\n if (!className) {\n return null;\n }\n return (moduleName != null ? moduleName + \".\" : \"\") + className;\n }\n /**\n * Returns a promise that resolves after the given amount of time.\n * @param delay Number of milliseconds to delay\n * @returns Promise that resolves after the given amount of time\n */\n static DelayAsync(delay) {\n return new Promise((resolve) => {\n setTimeout(() => {\n resolve();\n }, delay);\n });\n }\n /**\n * Utility function to detect if the current user agent is Safari\n * @returns whether or not the current user agent is safari\n */\n static IsSafari() {\n if (!IsNavigatorAvailable()) {\n return false;\n }\n return /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\n }\n}\n/**\n * Enable/Disable Custom HTTP Request Headers globally.\n * default = false\n * @see CustomRequestHeaders\n */\nTools.UseCustomRequestHeaders = false;\n/**\n * Custom HTTP Request Headers to be sent with XMLHttpRequests\n * i.e. when loading files, where the server/service expects an Authorization header\n */\nTools.CustomRequestHeaders = WebRequest.CustomRequestHeaders;\n/**\n * Extracts text content from a DOM element hierarchy\n * Back Compat only, please use GetDOMTextContent instead.\n */\nTools.GetDOMTextContent = GetDOMTextContent;\n/**\n * @internal\n */\nTools._DefaultCdnUrl = \"https://cdn.babylonjs.com\";\n// eslint-disable-next-line jsdoc/require-returns-check, jsdoc/require-param\n/**\n * @returns the absolute URL of a given (relative) url\n */\nTools.GetAbsoluteUrl = typeof document === \"object\"\n ? (url) => {\n const a = document.createElement(\"a\");\n a.href = url;\n return a.href;\n }\n : typeof URL === \"function\" && typeof location === \"object\"\n ? (url) => new URL(url, location.origin).href\n : () => {\n throw new Error(\"Unable to get absolute URL. Override BABYLON.Tools.GetAbsoluteUrl to a custom implementation for the current context.\");\n };\n// Logs\n/**\n * No log\n */\nTools.NoneLogLevel = Logger.NoneLogLevel;\n/**\n * Only message logs\n */\nTools.MessageLogLevel = Logger.MessageLogLevel;\n/**\n * Only warning logs\n */\nTools.WarningLogLevel = Logger.WarningLogLevel;\n/**\n * Only error logs\n */\nTools.ErrorLogLevel = Logger.ErrorLogLevel;\n/**\n * All logs\n */\nTools.AllLogLevel = Logger.AllLogLevel;\n/**\n * Checks if the window object exists\n * Back Compat only, please use IsWindowObjectExist instead.\n */\nTools.IsWindowObjectExist = IsWindowObjectExist;\n// Performances\n/**\n * No performance log\n */\nTools.PerformanceNoneLogLevel = 0;\n/**\n * Use user marks to log performance\n */\nTools.PerformanceUserMarkLogLevel = 1;\n/**\n * Log performance to the console\n */\nTools.PerformanceConsoleLogLevel = 2;\n/**\n * Starts a performance counter\n */\nTools.StartPerformanceCounter = Tools._StartPerformanceCounterDisabled;\n/**\n * Ends a specific performance counter\n */\nTools.EndPerformanceCounter = Tools._EndPerformanceCounterDisabled;\n/**\n * Use this className as a decorator on a given class definition to add it a name and optionally its module.\n * You can then use the Tools.getClassName(obj) on an instance to retrieve its class name.\n * This method is the only way to get it done in all cases, even if the .js file declaring the class is minified\n * @param name The name of the class, case should be preserved\n * @param module The name of the Module hosting the class, optional, but strongly recommended to specify if possible. Case should be preserved.\n * @returns a decorator function to apply on the class definition.\n */\nexport function className(name, module) {\n return (target) => {\n target[\"__bjsclassName__\"] = name;\n target[\"__bjsmoduleName__\"] = module != null ? module : null;\n };\n}\n/**\n * An implementation of a loop for asynchronous functions.\n */\nexport class AsyncLoop {\n /**\n * Constructor.\n * @param iterations the number of iterations.\n * @param func the function to run each iteration\n * @param successCallback the callback that will be called upon successful execution\n * @param offset starting offset.\n */\n constructor(\n /**\n * Defines the number of iterations for the loop\n */\n iterations, func, successCallback, offset = 0) {\n this.iterations = iterations;\n this.index = offset - 1;\n this._done = false;\n this._fn = func;\n this._successCallback = successCallback;\n }\n /**\n * Execute the next iteration. Must be called after the last iteration was finished.\n */\n executeNext() {\n if (!this._done) {\n if (this.index + 1 < this.iterations) {\n ++this.index;\n this._fn(this);\n }\n else {\n this.breakLoop();\n }\n }\n }\n /**\n * Break the loop and run the success callback.\n */\n breakLoop() {\n this._done = true;\n this._successCallback();\n }\n /**\n * Create and run an async loop.\n * @param iterations the number of iterations.\n * @param fn the function to run each iteration\n * @param successCallback the callback that will be called upon successful execution\n * @param offset starting offset.\n * @returns the created async loop object\n */\n static Run(iterations, fn, successCallback, offset = 0) {\n const loop = new AsyncLoop(iterations, fn, successCallback, offset);\n loop.executeNext();\n return loop;\n }\n /**\n * A for-loop that will run a given number of iterations synchronous and the rest async.\n * @param iterations total number of iterations\n * @param syncedIterations number of synchronous iterations in each async iteration.\n * @param fn the function to call each iteration.\n * @param callback a success call back that will be called when iterating stops.\n * @param breakFunction a break condition (optional)\n * @param timeout timeout settings for the setTimeout function. default - 0.\n * @returns the created async loop object\n */\n static SyncAsyncForLoop(iterations, syncedIterations, fn, callback, breakFunction, timeout = 0) {\n return AsyncLoop.Run(Math.ceil(iterations / syncedIterations), (loop) => {\n if (breakFunction && breakFunction()) {\n loop.breakLoop();\n }\n else {\n setTimeout(() => {\n for (let i = 0; i < syncedIterations; ++i) {\n const iteration = loop.index * syncedIterations + i;\n if (iteration >= iterations) {\n break;\n }\n fn(iteration);\n if (breakFunction && breakFunction()) {\n loop.breakLoop();\n break;\n }\n }\n loop.executeNext();\n }, timeout);\n }\n }, callback);\n }\n}\nTools.Mix = Mix;\nTools.IsExponentOfTwo = IsExponentOfTwo;\n// Will only be define if Tools is imported freeing up some space when only engine is required\nEngineStore.FallbackTexture =\n \"\";\n"],"mappings":"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","ignoreList":[]},"metadata":{},"sourceType":"module","externalDependencies":[]}