mirror of
https://github.com/thib8956/tic-tac-toe-ws.git
synced 2025-01-12 04:41:06 +00:00
implement hello message with player id
This commit is contained in:
parent
621d2489e4
commit
9625031969
17
client.mts
17
client.mts
@ -1,4 +1,4 @@
|
|||||||
import { Request, Response, Message } from "common.mjs";
|
import { Request, Response, Message, Hello } from "common.mjs";
|
||||||
|
|
||||||
const ws = new WebSocket("ws://localhost:1234");
|
const ws = new WebSocket("ws://localhost:1234");
|
||||||
const grid = [0, 0, 0, 0, 0, 0, 0, 0, 0]
|
const grid = [0, 0, 0, 0, 0, 0, 0, 0, 0]
|
||||||
@ -7,6 +7,7 @@ const ctx = canvas?.getContext("2d") as CanvasRenderingContext2D | null;
|
|||||||
|
|
||||||
ws.onopen = (e) => {
|
ws.onopen = (e) => {
|
||||||
console.log("connected to server");
|
console.log("connected to server");
|
||||||
|
|
||||||
if (canvas) {
|
if (canvas) {
|
||||||
if (ctx) {
|
if (ctx) {
|
||||||
drawGrid(ctx, grid);
|
drawGrid(ctx, grid);
|
||||||
@ -25,12 +26,22 @@ ws.onopen = (e) => {
|
|||||||
|
|
||||||
ws.onmessage = (evt) => {
|
ws.onmessage = (evt) => {
|
||||||
const msg: Message = JSON.parse(evt.data);
|
const msg: Message = JSON.parse(evt.data);
|
||||||
if (ctx && msg.kind == "update") {
|
switch (msg.kind) {
|
||||||
|
case "hello": {
|
||||||
|
const h1 = document.getElementById("title") as HTMLHeadingElement | null;
|
||||||
|
if (h1) {
|
||||||
|
h1.innerText = `connected to server with id ${(msg.data as Hello).id}`
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case "update": {
|
||||||
|
if (ctx) {
|
||||||
drawGrid(ctx, (msg.data as Response).grid);
|
drawGrid(ctx, (msg.data as Response).grid);
|
||||||
}
|
}
|
||||||
else {
|
}
|
||||||
|
default: {
|
||||||
console.log(msg);
|
console.log(msg);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@ export type MessageKind = "hello" | "update";
|
|||||||
|
|
||||||
export interface Message {
|
export interface Message {
|
||||||
kind: MessageKind,
|
kind: MessageKind,
|
||||||
data: Response | string,
|
data: Response | Hello,
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Request {
|
export interface Request {
|
||||||
@ -14,3 +14,7 @@ export interface Response {
|
|||||||
grid: number[]
|
grid: number[]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface Hello {
|
||||||
|
id: number
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<canvas id="game" width=800 height=600></canvas>
|
<canvas id="game" width=800 height=600></canvas>
|
||||||
|
<h1 id="title">Offline</h1>
|
||||||
</body>
|
</body>
|
||||||
<script type="module" src="client.mjs"></script>
|
<script type="module" src="client.mjs"></script>
|
||||||
</html>
|
</html>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { Message, Response } from "common.mjs"
|
import { Message, Response, Hello } from "common.mjs"
|
||||||
import { WebSocket, WebSocketServer } from "ws";
|
import { WebSocket, WebSocketServer } from "ws";
|
||||||
|
|
||||||
const port = 1234
|
const port = 1234
|
||||||
@ -18,7 +18,7 @@ wss.on("connection", (ws) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
clients.push(ws);
|
clients.push(ws);
|
||||||
ws.send(JSON.stringify({kind: "hello", data: `player #${id} connected`} as any));
|
ws.send(JSON.stringify({kind: "hello", data: { id } as Hello}));
|
||||||
console.log(`player #${id} connected`);
|
console.log(`player #${id} connected`);
|
||||||
|
|
||||||
ws.addEventListener("message", (event: any) => {
|
ws.addEventListener("message", (event: any) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user