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