123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- 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";
- }
- }
- }
|