139 lines
3.2 KiB
JavaScript
139 lines
3.2 KiB
JavaScript
import { GAME_HEIGHT, GAME_WIDTH, TILE_SIZE } from "./modules/constants.js";
|
|
import {
|
|
Camera,
|
|
CanvasResizer,
|
|
FpsCounter,
|
|
GameObject,
|
|
MapManagement,
|
|
} from "./modules/game-objects/index.js";
|
|
import { Player, SpriteSheet } from "./modules/game-objects/player.js";
|
|
|
|
const backgroundMaps = [
|
|
{
|
|
name: "overworld",
|
|
imageId: "overworld",
|
|
elementId: "level1",
|
|
layer: 0,
|
|
selected: true,
|
|
},
|
|
{ name: "ocean", imageId: "overworld", elementId: "level2" },
|
|
];
|
|
|
|
const foregroundMaps = [
|
|
{
|
|
name: "overworld",
|
|
imageId: "overworld",
|
|
elementId: "level1",
|
|
layer: 1,
|
|
selected: true,
|
|
},
|
|
{ name: "ocean", imageId: "overworld", elementId: "level2", layer: 2 },
|
|
];
|
|
|
|
const foregroundCollisionMaps = [
|
|
{
|
|
name: "overworld",
|
|
imageId: "overworld",
|
|
elementId: "level1",
|
|
layer: 2,
|
|
selected: true,
|
|
collision: true,
|
|
},
|
|
{
|
|
name: "ocean",
|
|
imageId: "overworld",
|
|
elementId: "level2",
|
|
layer: 2,
|
|
collision: true,
|
|
},
|
|
];
|
|
|
|
const clicableObjects = ["debug", "level1", "level2"];
|
|
|
|
const playerAnimations = {
|
|
idle: {
|
|
left: [51],
|
|
right: [17],
|
|
top: [34],
|
|
bottom: [0],
|
|
},
|
|
walk: {
|
|
left: [51, 52, 53, 54],
|
|
right: [17, 18, 19, 20],
|
|
top: [34, 35, 36, 37],
|
|
bottom: [0, 1, 2, 3],
|
|
},
|
|
};
|
|
|
|
class Game extends GameObject {
|
|
constructor({ canvas }) {
|
|
super();
|
|
|
|
const canvasResizer = new CanvasResizer({
|
|
canvas: canvas,
|
|
width: GAME_WIDTH,
|
|
height: GAME_HEIGHT,
|
|
percentage: 0.9,
|
|
});
|
|
const player = new Player({
|
|
speed: 1,
|
|
gameObjects: [new SpriteSheet({ imageId: "character", tileHeight: 32 })],
|
|
animations: playerAnimations,
|
|
x: 6 * TILE_SIZE,
|
|
y: 4 * TILE_SIZE,
|
|
width: TILE_SIZE,
|
|
height: 2 * TILE_SIZE,
|
|
});
|
|
const camera = new Camera({
|
|
gameObjects: [
|
|
new MapManagement({ maps: backgroundMaps }),
|
|
new MapManagement({ maps: foregroundMaps }),
|
|
player,
|
|
new MapManagement({ maps: foregroundCollisionMaps }),
|
|
],
|
|
target: player,
|
|
});
|
|
const fpsCounter = new FpsCounter();
|
|
this.gameObjects = [canvasResizer, camera, fpsCounter];
|
|
|
|
this.canvas = canvas;
|
|
this.ctx = this.canvas.getContext("2d");
|
|
this.lastTime = 0;
|
|
}
|
|
|
|
async load() {
|
|
await super.load();
|
|
clicableObjects.forEach((elementId) => {
|
|
document.getElementById(elementId).addEventListener("click", () => {
|
|
this.onMouseClick(elementId);
|
|
});
|
|
});
|
|
document.addEventListener("keydown", (event) => {
|
|
this.onKeyPressed(event.key);
|
|
});
|
|
document.addEventListener("keyup", (event) => {
|
|
this.onKeyReleased(event.key);
|
|
});
|
|
}
|
|
|
|
clear(ctx) {
|
|
ctx.clearRect(0, 0, this.canvas.width, this.canvas.height);
|
|
}
|
|
|
|
loop(time) {
|
|
const delta = (time - this.lastTime) / 1000;
|
|
this.lastTime = time;
|
|
this.update(delta);
|
|
this.clear(this.ctx);
|
|
this.render(this.ctx);
|
|
requestAnimationFrame(this.loop.bind(this));
|
|
}
|
|
}
|
|
|
|
async function run() {
|
|
const game = new Game({ canvas: document.getElementById("game") });
|
|
await game.load();
|
|
game.loop(0);
|
|
}
|
|
|
|
run();
|