From 3d77f1c26e2c7c3e961553c96f55df55efc924de Mon Sep 17 00:00:00 2001 From: Davide Tantillo Date: Thu, 26 Sep 2024 15:31:46 +0200 Subject: [PATCH] Removed custom LoadingSpinnerWindget class. Added a new specific method in LoadingSpinner. --- spine-ts/spine-webgl/example/canvas9.html | 4 +- spine-ts/spine-webgl/src/LoadingScreen.ts | 19 +++ .../spine-webgl/src/LoadingScreenWidget.ts | 129 ------------------ .../src/SpineWebComponentWidget.ts | 8 +- spine-ts/spine-webgl/src/index.ts | 1 - 5 files changed, 25 insertions(+), 136 deletions(-) delete mode 100644 spine-ts/spine-webgl/src/LoadingScreenWidget.ts diff --git a/spine-ts/spine-webgl/example/canvas9.html b/spine-ts/spine-webgl/example/canvas9.html index 827995575..bff8e1d3e 100644 --- a/spine-ts/spine-webgl/example/canvas9.html +++ b/spine-ts/spine-webgl/example/canvas9.html @@ -593,7 +593,7 @@ atlas="assets/spineboy-pma.atlas" skeleton="assets/spineboy-pro.skel" animation="walk" - spinner="false" + spinner >
@@ -638,7 +638,7 @@ atlas="assets/spineboy-pma.atlas" skeleton="assets/spineboy-pro.skel" animation="walk" - spinner="true" + spinner >`) diff --git a/spine-ts/spine-webgl/src/LoadingScreen.ts b/spine-ts/spine-webgl/src/LoadingScreen.ts index 30469f651..73395f2be 100644 --- a/spine-ts/spine-webgl/src/LoadingScreen.ts +++ b/spine-ts/spine-webgl/src/LoadingScreen.ts @@ -125,6 +125,25 @@ export class LoadingScreen implements Disposable { if (this.spinner) renderer.drawTextureRotated(this.spinner, (canvas.width - spinnerSize) / 2, (canvas.height - spinnerSize) / 2, spinnerSize, spinnerSize, spinnerSize / 2, spinnerSize / 2, this.angle, tempColor); renderer.end(); } + + drawInCoordinates (x: number, y: number) { + if (loaded < 2) return; + + this.timeKeeper.update(); + let renderer = this.renderer; + renderer.batcher.setBlendMode(BlendMode.Normal, true); + + if (!this.logo) { + this.logo = new GLTexture(renderer.context, logoImage); + this.spinner = new GLTexture(renderer.context, spinnerImage); + } + + const shiftedX = x - logoWidth / 2; + const shiftedY = y - logoHeight / 2; + renderer.drawTexture(this.logo, shiftedX, shiftedY, logoWidth, logoHeight); + + if (this.spinner) renderer.drawTextureRotated(this.spinner, shiftedX, shiftedY - 25, spinnerSize, spinnerSize, spinnerSize / 2, spinnerSize / 2, this.timeKeeper.delta * 500); + } } let SPINNER_DATA = ""; diff --git a/spine-ts/spine-webgl/src/LoadingScreenWidget.ts b/spine-ts/spine-webgl/src/LoadingScreenWidget.ts deleted file mode 100644 index fac9a372b..000000000 --- a/spine-ts/spine-webgl/src/LoadingScreenWidget.ts +++ /dev/null @@ -1,129 +0,0 @@ -/****************************************************************************** - * Spine Runtimes License Agreement - * Last updated July 28, 2023. Replaces all prior versions. - * - * Copyright (c) 2013-2023, Esoteric Software LLC - * - * Integration of the Spine Runtimes into software or otherwise creating - * derivative works of the Spine Runtimes is permitted under the terms and - * conditions of Section 2 of the Spine Editor License Agreement: - * http://esotericsoftware.com/spine-editor-license - * - * Otherwise, it is permitted to integrate the Spine Runtimes into software or - * otherwise create derivative works of the Spine Runtimes (collectively, - * "Products"), provided that each user of the Products must obtain their own - * Spine Editor license and redistribution of the Products in any form must - * include this license and copyright notice. - * - * THE SPINE RUNTIMES ARE PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, - * BUSINESS INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THE - * SPINE RUNTIMES, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - *****************************************************************************/ - -import { BlendMode, Color, Disposable, TimeKeeper } from "@esotericsoftware/spine-core"; -import { GLTexture } from "./GLTexture.js"; -import { ResizeMode, SceneRenderer } from "./SceneRenderer.js"; - -let spinnerImage: HTMLImageElement; -let logoImage: HTMLImageElement; -let loaded = 0; - -const FADE_IN = 1, FADE_OUT = 1; -const logoWidth = 165, logoHeight = 108, spinnerSize = 163; - -export class LoadingScreenWidget implements Disposable { - private renderer: SceneRenderer; - private logo: GLTexture | null = null; - private spinner: GLTexture | null = null; - private angle = 0; - private fadeOut = 0; - private fadeIn = 0; - private timeKeeper = new TimeKeeper(); - backgroundColor = new Color(0.135, 0.135, 0.135, 1); - private tempColor = new Color(); - - private x = 0; - private y = 0; - - constructor (renderer: SceneRenderer) { - this.renderer = renderer; - - this.timeKeeper.maxDelta = 9; - - if (!logoImage) { - let isSafari = navigator.userAgent.indexOf("Safari") > -1; // Thank you Apple Inc. - let onload = () => loaded++; - - logoImage = new Image(); - logoImage.src = SPINE_LOGO_DATA; - if (!isSafari) logoImage.crossOrigin = "anonymous"; - logoImage.onload = onload; - - spinnerImage = new Image(); - spinnerImage.src = SPINNER_DATA; - if (!isSafari) spinnerImage.crossOrigin = "anonymous"; - spinnerImage.onload = onload; - } - } - dispose (): void { - this.logo?.dispose(); - this.spinner?.dispose(); - } - - draw (complete = false, x: number, y: number, width: number, height: number) { - if (loaded < 2 || (complete && this.fadeOut > FADE_OUT)) return; - - this.x = x; - this.y = y; - - this.timeKeeper.update(); - // let a = Math.abs(Math.sin(this.timeKeeper.totalTime + 0.25)); - let a = 1; - this.angle -= this.timeKeeper.delta * 200 * (1 + 1.5 * Math.pow(a, 5)); - - let tempColor = this.tempColor; - let renderer = this.renderer; - - renderer.batcher.setBlendMode(BlendMode.Normal, true); - - // a *= Math.min(this.fadeIn / FADE_IN, 1); - tempColor.set(a, a, a, a); - - if (!this.logo) { - this.logo = new GLTexture(renderer.context, logoImage); - this.spinner = new GLTexture(renderer.context, spinnerImage); - } - - const shiftedX = this.x - logoWidth / 2; - const shiftedY = this.y - logoHeight / 2; - renderer.drawTexture( - this.logo, - shiftedX, - shiftedY, - logoWidth, - logoHeight, - tempColor); - - if (this.spinner) renderer.drawTextureRotated( - this.spinner, - shiftedX, - shiftedY - 25, - spinnerSize, - spinnerSize, - spinnerSize / 2, - spinnerSize / 2, - this.angle, - tempColor); - } -} - -let SPINNER_DATA = ""; - -let SPINE_LOGO_DATA = ""; diff --git a/spine-ts/spine-webgl/src/SpineWebComponentWidget.ts b/spine-ts/spine-webgl/src/SpineWebComponentWidget.ts index e78f5e5a4..4b7e8cf01 100644 --- a/spine-ts/spine-webgl/src/SpineWebComponentWidget.ts +++ b/spine-ts/spine-webgl/src/SpineWebComponentWidget.ts @@ -35,7 +35,7 @@ import { AssetManager, Color, Input, - LoadingScreenWidget, + LoadingScreen, ManagedWebGLRenderingContext, MixBlend, MixDirection, @@ -408,7 +408,7 @@ class SpineWebComponentWidget extends HTMLElement implements WidgetAttributes, W * This is instantiated only if it is really necessary. * For example, if {@link loadingSpinner} is `false`, this property value is null */ - public loadingScreen: LoadingScreenWidget | null = null; + public loadingScreen: LoadingScreen | null = null; /** * If true, the widget is in the assets loading process. @@ -1036,8 +1036,8 @@ class SpineWebComponentOverlay extends HTMLElement { if (loading) { if (loadingSpinner) { - if (!widget.loadingScreen) widget.loadingScreen = new LoadingScreenWidget(renderer); - widget.loadingScreen!.draw(true, divOriginX, divOriginY, divWidthWorld, divHeightWorld); + if (!widget.loadingScreen) widget.loadingScreen = new LoadingScreen(renderer); + widget.loadingScreen!.drawInCoordinates(divOriginX, divOriginY); } if (clip) clipToBoundEnd(); return; diff --git a/spine-ts/spine-webgl/src/index.ts b/spine-ts/spine-webgl/src/index.ts index 60c4695a0..975c56723 100644 --- a/spine-ts/spine-webgl/src/index.ts +++ b/spine-ts/spine-webgl/src/index.ts @@ -4,7 +4,6 @@ export * from "./CameraController.js"; export * from "./GLTexture.js"; export * from "./Input.js"; export * from "./LoadingScreen.js"; -export * from "./LoadingScreenWidget.js"; export * from "./Matrix4.js"; export * from "./Mesh.js"; export * from "./PolygonBatcher.js";