Removed custom LoadingSpinnerWindget class. Added a new specific method in LoadingSpinner.

This commit is contained in:
Davide Tantillo 2024-09-26 15:31:46 +02:00
parent 9399c42ec7
commit 3d77f1c26e
5 changed files with 25 additions and 136 deletions

View File

@ -593,7 +593,7 @@
atlas="assets/spineboy-pma.atlas"
skeleton="assets/spineboy-pro.skel"
animation="walk"
spinner="false"
spinner
></spine-widget>
</div>
<div class="split-right">
@ -638,7 +638,7 @@
atlas="assets/spineboy-pma.atlas"
skeleton="assets/spineboy-pro.skel"
animation="walk"
spinner="true"
spinner
></spine-widget>`)
</script>
</code></pre>

View File

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

File diff suppressed because one or more lines are too long

View File

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

View File

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