2024-04-01 19:56:46 -04:00
|
|
|
export const legacyCompatibleImages: string[] = [];
|
|
|
|
|
|
|
|
export class SceneBase extends Phaser.Scene {
|
|
|
|
constructor(config?: string | Phaser.Types.Scenes.SettingsConfig) {
|
|
|
|
super(config);
|
|
|
|
}
|
|
|
|
|
2024-04-23 22:00:23 -04: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-01 19:56:46 -04:00
|
|
|
loadImage(key: string, folder: string, filename?: string) {
|
|
|
|
if (!filename)
|
|
|
|
filename = `${key}.png`;
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.image(key, this.getCachedUrl(`images/${folder}/${filename}`));
|
2024-04-01 19:56:46 -04:00
|
|
|
if (folder.startsWith('ui')) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace('ui', 'ui/legacy');
|
2024-04-23 22:00:23 -04:00
|
|
|
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) {
|
|
|
|
if (!filename)
|
|
|
|
filename = `${key}.png`;
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.spritesheet(key, this.getCachedUrl(`images/${folder}/${filename}`), { frameWidth: size, frameHeight: size });
|
2024-04-01 19:56:46 -04:00
|
|
|
if (folder.startsWith('ui')) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace('ui', 'ui/legacy');
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.spritesheet(`${key}_legacy`, this.getCachedUrl(`images/${folder}/${filename}`), { frameWidth: size, frameHeight: size });
|
2024-04-01 19:56:46 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loadAtlas(key: string, folder: string, filenameRoot?: string) {
|
|
|
|
if (!filenameRoot)
|
|
|
|
filenameRoot = key;
|
|
|
|
if (folder)
|
|
|
|
folder += '/';
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.atlas(key, this.getCachedUrl(`images/${folder}${filenameRoot}.png`), this.getCachedUrl(`images/${folder}/${filenameRoot}.json`));
|
2024-04-01 19:56:46 -04:00
|
|
|
if (folder.startsWith('ui')) {
|
|
|
|
legacyCompatibleImages.push(key);
|
|
|
|
folder = folder.replace('ui', 'ui/legacy');
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.atlas(`${key}_legacy`, this.getCachedUrl(`images/${folder}${filenameRoot}.png`), this.getCachedUrl(`images/${folder}/${filenameRoot}.json`));
|
2024-04-01 19:56:46 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loadSe(key: string, folder?: string, filenames?: string | string[]) {
|
|
|
|
if (!filenames)
|
|
|
|
filenames = `${key}.wav`;
|
|
|
|
if (!folder)
|
|
|
|
folder = '';
|
|
|
|
else
|
|
|
|
folder += '/';
|
|
|
|
if (!Array.isArray(filenames))
|
|
|
|
filenames = [ filenames ];
|
2024-04-23 22:00:23 -04:00
|
|
|
for (let f of filenames as string[])
|
|
|
|
this.load.audio(key, this.getCachedUrl(`audio/se/${folder}${f}`));
|
2024-04-01 19:56:46 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
loadBgm(key: string, filename?: string) {
|
|
|
|
if (!filename)
|
|
|
|
filename = `${key}.mp3`;
|
2024-04-23 22:00:23 -04:00
|
|
|
this.load.audio(key, this.getCachedUrl(`audio/bgm/${filename}`));
|
2024-04-01 19:56:46 -04:00
|
|
|
}
|
|
|
|
}
|