2024-04-01 19:56:46 -04:00
|
|
|
export const legacyCompatibleImages: string[] = [];
|
|
|
|
|
|
|
|
export class SceneBase extends Phaser.Scene {
|
2024-06-19 15:40:08 -04:00
|
|
|
/**
|
|
|
|
* Since everything is scaled up by 6 by default using the game.canvas is annoying
|
|
|
|
* Until such point that we use the canvas normally, this will be easier than
|
|
|
|
* having to divide every width and heigh by 6 to position and scale the ui
|
|
|
|
* @readonly
|
|
|
|
* @defaultValue
|
|
|
|
* width: `320`
|
|
|
|
* height: `180`
|
|
|
|
*/
|
|
|
|
public readonly scaledCanvas = {
|
|
|
|
width: 1920 / 6,
|
|
|
|
height: 1080 / 6
|
|
|
|
};
|
2024-04-01 19:56:46 -04:00
|
|
|
constructor(config?: string | Phaser.Types.Scenes.SettingsConfig) {
|
|
|
|
super(config);
|
|
|
|
}
|
|
|
|
|
2024-05-23 17:03:10 +02:00
|
|
|
getCachedUrl(url: string): string {
|
|
|
|
const manifest = this.game["manifest"];
|
|
|
|
if (manifest) {
|
|
|
|
const timestamp = manifest[`/${url}`];
|
|
|
|
if (timestamp) {
|
|
|
|
url += `?t=${timestamp}`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return url;
|
|
|
|
}
|
2024-04-23 22:00:23 -04:00
|
|
|
|
2024-04-01 19:56:46 -04:00
|
|
|
loadImage(key: string, folder: string, filename?: string) {
|
2024-05-23 17:03:10 +02:00
|
|
|
if (!filename) {
|
|
|
|
filename = `${key}.png`;
|
|
|
|
}
|
|
|
|
this.load.image(key, this.getCachedUrl(`images/${folder}/${filename}`));
|
|
|
|
if (folder.startsWith("ui")) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace("ui", "ui/legacy");
|
|
|
|
this.load.image(`${key}_legacy`, this.getCachedUrl(`images/${folder}/${filename}`));
|
|
|
|
}
|
|
|
|
}
|
2024-04-01 19:56:46 -04:00
|
|
|
|
|
|
|
loadSpritesheet(key: string, folder: string, size: integer, filename?: string) {
|
2024-05-23 17:03:10 +02:00
|
|
|
if (!filename) {
|
|
|
|
filename = `${key}.png`;
|
|
|
|
}
|
|
|
|
this.load.spritesheet(key, this.getCachedUrl(`images/${folder}/${filename}`), { frameWidth: size, frameHeight: size });
|
|
|
|
if (folder.startsWith("ui")) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace("ui", "ui/legacy");
|
|
|
|
this.load.spritesheet(`${key}_legacy`, this.getCachedUrl(`images/${folder}/${filename}`), { frameWidth: size, frameHeight: size });
|
|
|
|
}
|
|
|
|
}
|
2024-04-01 19:56:46 -04:00
|
|
|
|
2024-05-23 17:03:10 +02:00
|
|
|
loadAtlas(key: string, folder: string, filenameRoot?: string) {
|
|
|
|
if (!filenameRoot) {
|
|
|
|
filenameRoot = key;
|
|
|
|
}
|
|
|
|
if (folder) {
|
|
|
|
folder += "/";
|
|
|
|
}
|
2024-05-28 16:08:53 +02:00
|
|
|
this.load.atlas(key, this.getCachedUrl(`images/${folder}${filenameRoot}.png`), this.getCachedUrl(`images/${folder}${filenameRoot}.json`));
|
2024-05-23 17:03:10 +02:00
|
|
|
if (folder.startsWith("ui")) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace("ui", "ui/legacy");
|
2024-05-28 16:08:53 +02:00
|
|
|
this.load.atlas(`${key}_legacy`, this.getCachedUrl(`images/${folder}${filenameRoot}.png`), this.getCachedUrl(`images/${folder}${filenameRoot}.json`));
|
2024-05-23 17:03:10 +02:00
|
|
|
}
|
|
|
|
}
|
2024-04-01 19:56:46 -04:00
|
|
|
|
2024-05-23 17:03:10 +02:00
|
|
|
loadSe(key: string, folder?: string, filenames?: string | string[]) {
|
|
|
|
if (!filenames) {
|
|
|
|
filenames = `${key}.wav`;
|
|
|
|
}
|
|
|
|
if (!folder) {
|
2024-08-25 09:40:14 -07:00
|
|
|
folder = "se/";
|
2024-05-23 17:03:10 +02:00
|
|
|
} else {
|
|
|
|
folder += "/";
|
|
|
|
}
|
|
|
|
if (!Array.isArray(filenames)) {
|
|
|
|
filenames = [ filenames ];
|
|
|
|
}
|
|
|
|
for (const f of filenames as string[]) {
|
2024-08-25 09:40:14 -07:00
|
|
|
this.load.audio(folder+key, this.getCachedUrl(`audio/${folder}${f}`));
|
2024-05-23 17:03:10 +02:00
|
|
|
}
|
|
|
|
}
|
2024-04-01 19:56:46 -04:00
|
|
|
|
2024-05-23 17:03:10 +02:00
|
|
|
loadBgm(key: string, filename?: string) {
|
|
|
|
if (!filename) {
|
|
|
|
filename = `${key}.mp3`;
|
|
|
|
}
|
|
|
|
this.load.audio(key, this.getCachedUrl(`audio/bgm/${filename}`));
|
|
|
|
}
|
|
|
|
}
|