diff options
| author | metamuffin <metamuffin@disroot.org> | 2024-06-17 00:30:38 +0200 | 
|---|---|---|
| committer | metamuffin <metamuffin@disroot.org> | 2024-06-17 00:30:38 +0200 | 
| commit | e37231630488e5b54741d68edc45890a62c5610d (patch) | |
| tree | 8be6237564176635a7f5d323d1fb5e417f9b8119 /test-client | |
| parent | dd4b88a86a99f028bdfe66fef3c66170629f3cdc (diff) | |
| download | hurrycurry-e37231630488e5b54741d68edc45890a62c5610d.tar hurrycurry-e37231630488e5b54741d68edc45890a62c5610d.tar.bz2 hurrycurry-e37231630488e5b54741d68edc45890a62c5610d.tar.zst | |
client connects and can speak proto
Diffstat (limited to 'test-client')
| -rw-r--r-- | test-client/main.ts | 75 | ||||
| -rw-r--r-- | test-client/protocol.ts | 24 | 
2 files changed, 92 insertions, 7 deletions
| diff --git a/test-client/main.ts b/test-client/main.ts index bc0872a6..d093c62e 100644 --- a/test-client/main.ts +++ b/test-client/main.ts @@ -1,5 +1,7 @@  /// <reference lib="dom" /> +import { PacketC, PacketS } from "./protocol.ts"; +  let ctx: CanvasRenderingContext2D;  let canvas: HTMLCanvasElement;  let ws: WebSocket @@ -7,10 +9,13 @@ document.addEventListener("DOMContentLoaded", () => {      ws = new WebSocket(`${window.location.protocol.endsWith("s:") ? "wss" : "ws"}://${window.location.hostname}:27032/`)      ws.onerror = console.error      ws.onmessage = m => { -        console.log(JSON.parse(m.data)); +        packet(JSON.parse(m.data) as PacketC); +    } +    ws.onclose = () => console.log("close") +    ws.onopen = () => { +        console.log("open") +        send({ join: { name: "test" } })      } -    ws.onclose = () => console.warn("close") -    ws.onopen = () => console.warn("open")      canvas = document.createElement("canvas");      document.body.append(canvas) @@ -20,15 +25,75 @@ document.addEventListener("DOMContentLoaded", () => {      draw()  }) +interface Player { x: number; y: number, name: string, rot: number } +const players = new Map<number, Player>() +interface Item { x: number; y: number } +const items = new Map<number, Item>() +interface Tile { x: number; y: number } +const tiles = new Map<string, Tile>() +let my_id = undefined + +function send(p: PacketS) { ws.send(JSON.stringify(p)) } +function packet(p: PacketC) { +    if ("joined" in p) { +        my_id = p.joined.id +    } else if ("add_player" in p) { +        players.set(p.add_player.id, { x: 0, y: 0, name: p.add_player.name, rot: 0 }) +    } else if ("remove_player" in p) { +        players.delete(p.remove_player.id) +    } else if ("position" in p) { +        const pl = players.get(p.position.player)! +        pl.x = p.position.pos[0] +        pl.y = p.position.pos[1] +        pl.rot = p.position.rot +    } else if ("take_item" in p) { +    } else if ("put_item" in p) { +    } else if ("produce_item" in p) { +    } else if ("consume_item" in p) { +    } else if ("set_active" in p) { +    } else if ("update_map" in p) { +    } else console.warn("unknown packet", p); +} + +  function resize() {      canvas.width = globalThis.innerWidth      canvas.height = globalThis.innerHeight  }  function draw() { -    ctx.fillStyle = "black" +    if (ws.readyState == ws.CONNECTING) draw_wait("Connecting...") +    else if (ws.readyState == ws.CLOSING) draw_wait("Closing...") +    else if (ws.readyState == ws.CLOSED) draw_wait("Disconnected") +    else if (ws.readyState == ws.OPEN) draw_ingame() +    else throw new Error(`ws state invalid`); +    requestAnimationFrame(draw) +} +function draw_wait(text: string) { +    ctx.fillStyle = "gray"      ctx.fillRect(0, 0, canvas.width, canvas.height) +    ctx.fillStyle = "#555" +    ctx.font = "50px sans-serif" +    ctx.strokeStyle = "black" +    ctx.fillStyle = "white" +    ctx.lineWidth = 10 +    ctx.textAlign = "center" +    ctx.textBaseline = "middle" +    ctx.strokeText(text, canvas.width / 2, canvas.height / 2) +    ctx.fillText(text, canvas.width / 2, canvas.height / 2) +} -    requestAnimationFrame(draw) +function draw_ingame() { +    ctx.fillStyle = "#111" +    ctx.fillRect(0, 0, canvas.width, canvas.height) + +    for (const [_, player] of players) { +        ctx.save() +        ctx.translate(player.x, player.y) +        ctx.rotate(player.rot) +        ctx.fillStyle = "rgb(226, 176, 26)" +        ctx.fillRect(-0.5, -0.5, 1, 1) +        ctx.restore() +    }  } diff --git a/test-client/protocol.ts b/test-client/protocol.ts index 9761f152..3b61ce94 100644 --- a/test-client/protocol.ts +++ b/test-client/protocol.ts @@ -1,4 +1,24 @@ +export type ID = number; +export type Vec2 = [number, number] +export type Item = string +export type Tile = string +export type PacketS = +    { join: { name: string } } +    | "leave" +    | { position: { pos: Vec2, rot: number } } +    | { interact: { pos: Vec2 } } + + +export type PacketC = +    { joined: { id: ID } } +    | { add_player: { id: ID, name: string } } +    | { remove_player: { id: ID } } +    | { position: { player: ID, pos: Vec2, rot: number } } +    | { take_item: { item: ID, player: ID } } +    | { put_item: { item: ID, pos: Vec2 } } +    | { produce_item: { id: ID, pos: Vec2, kind: Item } } +    | { consume_item: { id: ID, pos: Vec2 } } +    | { set_active: { tile: Vec2 } } +    | { update_map: { pos: Vec2, tile: Tile } } -export type PacketS = {} -export type PacketC = {} | 
