123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- import { AbstractEngine } from "../Engines/abstractEngine.js";
- /**
- * Class used for the default loading screen
- * @see https://doc.babylonjs.com/features/featuresDeepDive/scene/customLoadingScreen
- */
- export class DefaultLoadingScreen {
- /**
- * Creates a new default loading screen
- * @param _renderingCanvas defines the canvas used to render the scene
- * @param _loadingText defines the default text to display
- * @param _loadingDivBackgroundColor defines the default background color
- */
- constructor(_renderingCanvas, _loadingText = "", _loadingDivBackgroundColor = "black") {
- this._renderingCanvas = _renderingCanvas;
- this._loadingText = _loadingText;
- this._loadingDivBackgroundColor = _loadingDivBackgroundColor;
- // Resize
- this._resizeLoadingUI = () => {
- const canvasRect = this._renderingCanvas.getBoundingClientRect();
- const canvasPositioning = window.getComputedStyle(this._renderingCanvas).position;
- if (!this._loadingDiv) {
- return;
- }
- this._loadingDiv.style.position = canvasPositioning === "fixed" ? "fixed" : "absolute";
- this._loadingDiv.style.left = canvasRect.left + "px";
- this._loadingDiv.style.top = canvasRect.top + "px";
- this._loadingDiv.style.width = canvasRect.width + "px";
- this._loadingDiv.style.height = canvasRect.height + "px";
- };
- }
- /**
- * Function called to display the loading screen
- */
- displayLoadingUI() {
- if (this._loadingDiv) {
- // Do not add a loading screen if there is already one
- return;
- }
- this._loadingDiv = document.createElement("div");
- this._loadingDiv.id = "babylonjsLoadingDiv";
- this._loadingDiv.style.opacity = "0";
- this._loadingDiv.style.transition = "opacity 1.5s ease";
- this._loadingDiv.style.pointerEvents = "none";
- this._loadingDiv.style.display = "grid";
- this._loadingDiv.style.gridTemplateRows = "100%";
- this._loadingDiv.style.gridTemplateColumns = "100%";
- this._loadingDiv.style.justifyItems = "center";
- this._loadingDiv.style.alignItems = "center";
- // Loading text
- this._loadingTextDiv = document.createElement("div");
- this._loadingTextDiv.style.position = "absolute";
- this._loadingTextDiv.style.left = "0";
- this._loadingTextDiv.style.top = "50%";
- this._loadingTextDiv.style.marginTop = "80px";
- this._loadingTextDiv.style.width = "100%";
- this._loadingTextDiv.style.height = "20px";
- this._loadingTextDiv.style.fontFamily = "Arial";
- this._loadingTextDiv.style.fontSize = "14px";
- this._loadingTextDiv.style.color = "white";
- this._loadingTextDiv.style.textAlign = "center";
- this._loadingTextDiv.style.zIndex = "1";
- this._loadingTextDiv.innerHTML = "Loading";
- this._loadingDiv.appendChild(this._loadingTextDiv);
- //set the predefined text
- this._loadingTextDiv.innerHTML = this._loadingText;
- // Generating keyframes
- this._style = document.createElement("style");
- this._style.type = "text/css";
- const keyFrames = `@-webkit-keyframes spin1 {\
- 0% { -webkit-transform: rotate(0deg);}
- 100% { -webkit-transform: rotate(360deg);}
- }\
- @keyframes spin1 {\
- 0% { transform: rotate(0deg);}
- 100% { transform: rotate(360deg);}
- }`;
- this._style.innerHTML = keyFrames;
- document.getElementsByTagName("head")[0].appendChild(this._style);
- const svgSupport = !!window.SVGSVGElement;
- // Loading img
- const imgBack = new Image();
- if (!DefaultLoadingScreen.DefaultLogoUrl) {
- imgBack.src = !svgSupport
- ? "https://cdn.babylonjs.com/Assets/babylonLogo.png"
- : ``;
- }
- else {
- imgBack.src = DefaultLoadingScreen.DefaultLogoUrl;
- }
- imgBack.style.width = "150px";
- imgBack.style.gridColumn = "1";
- imgBack.style.gridRow = "1";
- imgBack.style.top = "50%";
- imgBack.style.left = "50%";
- imgBack.style.transform = "translate(-50%, -50%)";
- imgBack.style.position = "absolute";
- const imageSpinnerContainer = document.createElement("div");
- imageSpinnerContainer.style.width = "300px";
- imageSpinnerContainer.style.gridColumn = "1";
- imageSpinnerContainer.style.gridRow = "1";
- imageSpinnerContainer.style.top = "50%";
- imageSpinnerContainer.style.left = "50%";
- imageSpinnerContainer.style.transform = "translate(-50%, -50%)";
- imageSpinnerContainer.style.position = "absolute";
- // Loading spinner
- const imgSpinner = new Image();
- if (!DefaultLoadingScreen.DefaultSpinnerUrl) {
- imgSpinner.src = !svgSupport
- ? "https://cdn.babylonjs.com/Assets/loadingIcon.png"
- : ``;
- }
- else {
- imgSpinner.src = DefaultLoadingScreen.DefaultSpinnerUrl;
- }
- imgSpinner.style.animation = "spin1 0.75s infinite linear";
- imgSpinner.style.webkitAnimation = "spin1 0.75s infinite linear";
- imgSpinner.style.transformOrigin = "50% 50%";
- imgSpinner.style.webkitTransformOrigin = "50% 50%";
- if (!svgSupport) {
- const logoSize = { w: 16, h: 18.5 };
- const loadingSize = { w: 30, h: 30 };
- // set styling correctly
- imgBack.style.width = `${logoSize.w}vh`;
- imgBack.style.height = `${logoSize.h}vh`;
- imgBack.style.left = `calc(50% - ${logoSize.w / 2}vh)`;
- imgBack.style.top = `calc(50% - ${logoSize.h / 2}vh)`;
- imgSpinner.style.width = `${loadingSize.w}vh`;
- imgSpinner.style.height = `${loadingSize.h}vh`;
- imgSpinner.style.left = `calc(50% - ${loadingSize.w / 2}vh)`;
- imgSpinner.style.top = `calc(50% - ${loadingSize.h / 2}vh)`;
- }
- imageSpinnerContainer.appendChild(imgSpinner);
- this._loadingDiv.appendChild(imgBack);
- this._loadingDiv.appendChild(imageSpinnerContainer);
- this._resizeLoadingUI();
- window.addEventListener("resize", this._resizeLoadingUI);
- this._loadingDiv.style.backgroundColor = this._loadingDivBackgroundColor;
- document.body.appendChild(this._loadingDiv);
- this._loadingDiv.style.opacity = "1";
- }
- /**
- * Function called to hide the loading screen
- */
- hideLoadingUI() {
- if (!this._loadingDiv) {
- return;
- }
- const onTransitionEnd = () => {
- if (this._loadingTextDiv) {
- this._loadingTextDiv.remove();
- this._loadingTextDiv = null;
- }
- if (this._loadingDiv) {
- this._loadingDiv.remove();
- this._loadingDiv = null;
- }
- if (this._style) {
- this._style.remove();
- this._style = null;
- }
- window.removeEventListener("resize", this._resizeLoadingUI);
- };
- this._loadingDiv.style.opacity = "0";
- this._loadingDiv.addEventListener("transitionend", onTransitionEnd);
- }
- /**
- * Gets or sets the text to display while loading
- */
- set loadingUIText(text) {
- this._loadingText = text;
- if (this._loadingTextDiv) {
- this._loadingTextDiv.innerHTML = this._loadingText;
- }
- }
- get loadingUIText() {
- return this._loadingText;
- }
- /**
- * Gets or sets the color to use for the background
- */
- get loadingUIBackgroundColor() {
- return this._loadingDivBackgroundColor;
- }
- set loadingUIBackgroundColor(color) {
- this._loadingDivBackgroundColor = color;
- if (!this._loadingDiv) {
- return;
- }
- this._loadingDiv.style.backgroundColor = this._loadingDivBackgroundColor;
- }
- }
- /** Gets or sets the logo url to use for the default loading screen */
- DefaultLoadingScreen.DefaultLogoUrl = "";
- /** Gets or sets the spinner url to use for the default loading screen */
- DefaultLoadingScreen.DefaultSpinnerUrl = "";
- AbstractEngine.DefaultLoadingScreenFactory = (canvas) => {
- return new DefaultLoadingScreen(canvas);
- };
- //# sourceMappingURL=loadingScreen.js.map
|