41 lines
978 B
TypeScript
41 lines
978 B
TypeScript
import type { SpriteSpec } from "./sprites";
|
|
import { SPRITE_SPECS } from "./sprites";
|
|
|
|
export const IMAGES = new Map<string, HTMLImageElement>();
|
|
|
|
export const loadSpritesIntoImageElements = (
|
|
spriteSpecs: Partial<SpriteSpec>[]
|
|
): Promise<void>[] => {
|
|
const spritePromises: Promise<void>[] = [];
|
|
|
|
for (const spriteSpec of spriteSpecs) {
|
|
if (spriteSpec.sheet) {
|
|
const img = new Image();
|
|
img.src = spriteSpec.sheet;
|
|
IMAGES.set(spriteSpec.sheet, img);
|
|
|
|
spritePromises.push(
|
|
new Promise((resolve) => {
|
|
img.onload = () => resolve();
|
|
})
|
|
);
|
|
}
|
|
|
|
if (spriteSpec.states) {
|
|
spritePromises.push(
|
|
...loadSpritesIntoImageElements(Object.values(spriteSpec.states))
|
|
);
|
|
}
|
|
}
|
|
|
|
return spritePromises;
|
|
};
|
|
|
|
export const loadAssets = () =>
|
|
Promise.all([
|
|
...loadSpritesIntoImageElements(
|
|
Array.from(SPRITE_SPECS.keys()).map((key) => SPRITE_SPECS.get(key))
|
|
),
|
|
// TODO: Sound
|
|
]);
|