2024-05-19 04:37:53 +00:00
|
|
|
console.log("loading player system");
|
|
|
|
|
2024-05-19 22:07:43 +00:00
|
|
|
const collision = (entity) => {
|
|
|
|
// look through engine's collision components for overlap
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2024-05-19 04:37:53 +00:00
|
|
|
const playerSystem = (engine) => {
|
|
|
|
const entity = document.getElementById("player");
|
2024-05-20 19:40:17 +00:00
|
|
|
const movementRate = 0.5;
|
2024-05-19 04:37:53 +00:00
|
|
|
engine("registerEntity", entity);
|
2024-05-20 19:40:17 +00:00
|
|
|
const playerTransform = engine ("getComponentContructor", "transform")(entity);
|
2024-05-19 04:37:53 +00:00
|
|
|
|
|
|
|
const move = (direction) => (delta, eventData) => {
|
2024-05-19 22:07:43 +00:00
|
|
|
let translation = [0,0];
|
2024-05-19 04:37:53 +00:00
|
|
|
switch (direction) {
|
|
|
|
case "left":
|
2024-05-19 22:07:43 +00:00
|
|
|
translation [0] = -( movementRate * delta );
|
2024-05-19 04:37:53 +00:00
|
|
|
break;
|
|
|
|
case "right":
|
2024-05-19 22:07:43 +00:00
|
|
|
translation[0] = movementRate * delta;
|
2024-05-19 04:37:53 +00:00
|
|
|
break;
|
|
|
|
case "up":
|
2024-05-19 22:07:43 +00:00
|
|
|
translation[1] = - ( movementRate * delta );
|
2024-05-19 04:37:53 +00:00
|
|
|
break;
|
|
|
|
case "down":
|
2024-05-19 22:07:43 +00:00
|
|
|
translation[1] = movementRate * delta;
|
2024-05-19 04:37:53 +00:00
|
|
|
break;
|
|
|
|
}
|
2024-05-19 22:07:43 +00:00
|
|
|
playerTransform("translate", translation);
|
2024-05-19 04:37:53 +00:00
|
|
|
};
|
|
|
|
|
2024-05-19 22:07:43 +00:00
|
|
|
engine("registerEntity", entity);
|
|
|
|
engine("addComponent", entity, "transform", playerTransform);
|
|
|
|
// engine("")
|
2024-05-19 04:37:53 +00:00
|
|
|
engine("subscribeToEvent", "moveLeft", "movePlayerLeft", move("left"));
|
|
|
|
engine("subscribeToEvent", "moveRight", "movePlayerRight", move("right"));
|
|
|
|
engine("subscribeToEvent", "moveUp", "movePlayerUp", move("up"));
|
|
|
|
engine("subscribeToEvent", "moveDown", "movePlayerDown", move("down"));
|
|
|
|
};
|