module BABYLON { export interface ILoadingScreen { displayLoadingUI: () => void; hideLoadingUI: () => void; //default loader support loadingUIBackgroundColor: string; loadingUIText: string; } export class DefaultLoadingScreen implements ILoadingScreen { private _loadingDiv: HTMLDivElement; private _loadingTextDiv: HTMLDivElement; constructor(private _renderingCanvas: HTMLCanvasElement, private _loadingText = "", private _loadingDivBackgroundColor = "black") { } public displayLoadingUI(): void { 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"; // 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.innerHTML = "Loading"; this._loadingDiv.appendChild(this._loadingTextDiv); //set the predefined text this._loadingTextDiv.innerHTML = this._loadingText; // Loading img var imgBack = new Image(); imgBack.src = ""; imgBack.style.position = "absolute"; imgBack.style.left = "50%"; imgBack.style.top = "50%"; imgBack.style.marginLeft = "-50px"; imgBack.style.marginTop = "-50px"; imgBack.style.transition = "transform 1.0s ease"; imgBack.style.webkitTransition = "-webkit-transform 1.0s ease"; var deg = 360; var onTransitionEnd = () => { deg += 360; imgBack.style.transform = "rotateZ(" + deg + "deg)"; imgBack.style.webkitTransform = "rotateZ(" + deg + "deg)"; } imgBack.addEventListener("transitionend", onTransitionEnd); imgBack.addEventListener("webkitTransitionEnd", onTransitionEnd); this._loadingDiv.appendChild(imgBack); // front image var imgFront = new Image(); imgFront.src = ""; imgFront.style.position = "absolute"; imgFront.style.left = "50%"; imgFront.style.top = "50%"; imgFront.style.marginLeft = "-50px"; imgFront.style.marginTop = "-50px"; this._loadingDiv.appendChild(imgFront); this._resizeLoadingUI(); window.addEventListener("resize", this._resizeLoadingUI); this._loadingDiv.style.backgroundColor = this._loadingDivBackgroundColor; document.body.appendChild(this._loadingDiv); setTimeout(() => { this._loadingDiv.style.opacity = "1"; imgBack.style.transform = "rotateZ(360deg)"; imgBack.style.webkitTransform = "rotateZ(360deg)"; }, 0); } public hideLoadingUI(): void { if (!this._loadingDiv) { return; } var onTransitionEnd = () => { if (!this._loadingDiv) { return; } document.body.removeChild(this._loadingDiv); window.removeEventListener("resize", this._resizeLoadingUI); this._loadingDiv = null; } this._loadingDiv.style.opacity = "0"; this._loadingDiv.addEventListener("transitionend", onTransitionEnd); } public set loadingUIText(text: string) { this._loadingText = text; if (this._loadingTextDiv) { this._loadingTextDiv.innerHTML = this._loadingText; } } public get loadingUIBackgroundColor(): string { return this._loadingDivBackgroundColor; } public set loadingUIBackgroundColor(color: string) { this._loadingDivBackgroundColor = color; if (!this._loadingDiv) { return; } this._loadingDiv.style.backgroundColor = this._loadingDivBackgroundColor; } // Resize private _resizeLoadingUI = () => { var canvasRect = this._renderingCanvas.getBoundingClientRect(); this._loadingDiv.style.position = "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"; } } }