-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
112 lines (94 loc) · 2.54 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
//server setup
const express = require("express");
const app = express();
const http = require("http");
const server = http.createServer(app);
const { Server } = require("socket.io");
const io = new Server(server);
const Y_SPEED = 20;
const X_SPEED = 20;
const CANVAS_HEIGHT = 750;
const CANVAS_WIDTH = 1400;
const TICKRATE_MS = 100;
const players = new Map();
let currId = 0;
let change = false;
app.get("/", (_, res) => {
res.sendFile(__dirname + "/index.html");
});
app.get("/js/script.js", (_, res) => {
res.sendFile(__dirname + "/js/script.js");
});
app.get("/css/style.css", (_, res) => {
res.sendFile(__dirname + "/css/style.css");
});
app.get("/avatarPengu", (_, res) => {
res.sendFile(__dirname + "/assets/chinstrap.png");
});
app.get("/player.png", (_, res) => {
res.sendFile(__dirname + "/assets/spritesheet.png");
});
app.get("/beer.png", (_, res) => {
res.sendFile(__dirname + "/assets/beer.png");
});
io.on("connection", (socket) => {
let newPlayer = {
id: currId,
displayName: "Player " + currId++,
positionX: 0,
positionY: 0,
anim: "front",
};
players.set(socket, newPlayer);
io.emit("move", Array.from(players.values()));
console.log("connected");
change = true;
socket.on("disconnect", () => {
console.log("disconnected");
io.emit("player_exit", players.get(socket).id);
players.delete(socket);
});
//TODO: FIX CONCURRENCY
socket.emit("playerId", currId);
socket.on("msg", (msg) => {
const name = players.get(socket).displayName;
io.emit("msg", name + ": " + msg);
console.log(name + ": " + msg);
});
socket.on("draw", (imgURL) => {
const name = players.get(socket).displayName;
io.emit("draw", imgURL);
console.log(name + " sent a drawing!");
});
socket.on("move", (msg) => {
let move = JSON.parse(msg);
let player = players.get(socket);
if (move.moveX === -1) {
player.positionX -= X_SPEED;
player.anim = "left";
} else if (move.moveX === 1) {
player.positionX += X_SPEED;
player.anim = "right";
}
if (move.moveY === -1) {
player.positionY -= Y_SPEED;
player.anim = "up";
} else if (move.moveY === 1) {
player.positionY += Y_SPEED;
player.anim = "down";
}
if (move.moveX === 0 && move.moveY === 0) {
player.anim = "front";
}
change = true;
});
});
setInterval(function () {
if (change) {
io.emit("move", Array.from(players.values()));
change = false;
}
}, TICKRATE_MS);
server.listen(3000, () => {
console.log("listening on http://localhost:3000");
});