Browse Source

* Added color customization

* Fixed frontend saying "matchmaking" after match ended
master
vvandenb 2 years ago
parent
commit
defb57383c
  1. 8
      front/volume/src/components/Pong/Ball.ts
  2. 10
      front/volume/src/components/Pong/ColorPicker.svelte
  3. 20
      front/volume/src/components/Pong/Game.ts
  4. 5
      front/volume/src/components/Pong/Paddle.ts
  5. 4
      front/volume/src/components/Pong/Player.ts
  6. 18
      front/volume/src/components/Pong/Pong.svelte
  7. 2
      front/volume/src/components/Pong/utils.ts

8
front/volume/src/components/Pong/Ball.ts

@ -3,17 +3,15 @@ import { Point, Rect } from "./utils";
export class Ball { export class Ball {
rect: Rect; rect: Rect;
speed: Point; speed: Point;
color: string | CanvasGradient | CanvasPattern = "white";
constructor( constructor(
spawn: Point, spawn: Point,
size: Point = new Point(20, 20), size: Point = new Point(20, 20)
speed: Point = new Point(10, 2)
) { ) {
this.rect = new Rect(spawn, size); this.rect = new Rect(spawn, size);
} }
draw(context: CanvasRenderingContext2D) { draw(context: CanvasRenderingContext2D, color: string) {
this.rect.draw(context, this.color); this.rect.draw(context, color);
} }
} }

10
front/volume/src/components/Pong/ColorPicker.svelte

@ -0,0 +1,10 @@
<script lang="ts">
export let color: string;
</script>
<div>
<input type="color" bind:value={color}>
</div>
<style>
</style>

20
front/volume/src/components/Pong/Game.ts

@ -6,7 +6,6 @@ import { Paddle } from "./Paddle";
import { Player } from "./Player"; import { Player } from "./Player";
import { formatWebsocketData, Point, Rect } from "./utils"; import { formatWebsocketData, Point, Rect } from "./utils";
const BG_COLOR = "black";
const FPS = import.meta.env.VITE_FRONT_FPS; const FPS = import.meta.env.VITE_FRONT_FPS;
export class Game { export class Game {
@ -18,14 +17,18 @@ export class Game {
id: string; id: string;
walls: Rect[]; walls: Rect[];
drawInterval: NodeJS.Timer; drawInterval: NodeJS.Timer;
elementsColor: string;
backgroundColor: string;
constructor(canvas: HTMLCanvasElement, context: CanvasRenderingContext2D) { constructor(canvas: HTMLCanvasElement, context: CanvasRenderingContext2D, elementsColor: string, backgroundColor: string) {
this.canvas = canvas; this.canvas = canvas;
this.context = context; this.context = context;
this.players = []; this.players = [];
this.my_paddle = null; this.my_paddle = null;
this.walls = []; this.walls = [];
this.drawInterval = null; this.drawInterval = null;
this.elementsColor = elementsColor;
this.backgroundColor = backgroundColor;
} }
setInfo(data: GameInfo) { setInfo(data: GameInfo) {
@ -86,13 +89,18 @@ export class Game {
} }
} }
updateColors(elementsColor: string, backgroundColor: string) {
this.elementsColor = elementsColor;
this.backgroundColor = backgroundColor;
}
draw() { draw() {
this.context.fillStyle = BG_COLOR; this.context.fillStyle = this.backgroundColor;
this.context.fillRect(0, 0, this.canvas.width, this.canvas.height); this.context.fillRect(0, 0, this.canvas.width, this.canvas.height);
this.walls.forEach((w) => w.draw(this.context, "white")); this.walls.forEach((w) => w.draw(this.context, this.elementsColor));
this.players.forEach((p) => p.draw(this.context)); this.players.forEach((p) => p.draw(this.context, this.elementsColor));
this.ball.draw(this.context); this.ball.draw(this.context, this.elementsColor);
const max_width = 50; const max_width = 50;
this.context.font = "50px Arial"; this.context.font = "50px Arial";

5
front/volume/src/components/Pong/Paddle.ts

@ -2,14 +2,13 @@ import { Point, Rect } from "./utils";
export class Paddle { export class Paddle {
rect: Rect; rect: Rect;
color: string | CanvasGradient | CanvasPattern = "white";
constructor(spawn: Point, size: Point = new Point(6, 100)) { constructor(spawn: Point, size: Point = new Point(6, 100)) {
this.rect = new Rect(spawn, size); this.rect = new Rect(spawn, size);
} }
draw(context: CanvasRenderingContext2D) { draw(context: CanvasRenderingContext2D, color: string) {
this.rect.draw(context, this.color); this.rect.draw(context, color);
} }
move(e: MouseEvent) { move(e: MouseEvent) {

4
front/volume/src/components/Pong/Player.ts

@ -9,8 +9,8 @@ export class Player {
this.score = 0; this.score = 0;
} }
draw(context: CanvasRenderingContext2D) { draw(context: CanvasRenderingContext2D, color: string) {
this.paddle.draw(context); this.paddle.draw(context, color);
} }
drawScore( drawScore(

18
front/volume/src/components/Pong/Pong.svelte

@ -9,6 +9,7 @@
import Matchmaking from "./Matchmaking.svelte"; import Matchmaking from "./Matchmaking.svelte";
import type { MatchmakingDto } from "./dtos/MatchmakingDto"; import type { MatchmakingDto } from "./dtos/MatchmakingDto";
import { store } from "../../Auth"; import { store } from "../../Auth";
import ColorPicker from "./ColorPicker.svelte";
const SERVER_URL = `ws://${import.meta.env.VITE_HOST}:${ const SERVER_URL = `ws://${import.meta.env.VITE_HOST}:${
import.meta.env.VITE_BACK_PORT import.meta.env.VITE_BACK_PORT
@ -23,19 +24,23 @@
let loggedIn: boolean = false; let loggedIn: boolean = false;
let socket: WebSocket; let socket: WebSocket;
let username: string = $store.username; let username: string = $store.username;
let elementsColor: string = "#FFFFFF";
let backgroundColor: string = "#000000";
let game: Game;
function setupSocket( function setupSocket(
canvas: HTMLCanvasElement, canvas: HTMLCanvasElement,
context: CanvasRenderingContext2D context: CanvasRenderingContext2D
) { ) {
socket = new WebSocket(SERVER_URL); socket = new WebSocket(SERVER_URL);
const game = new Game(canvas, context); game = new Game(canvas, context, elementsColor, backgroundColor);
socket.onmessage = function (e) { socket.onmessage = function (e) {
const event_json = JSON.parse(e.data); const event_json = JSON.parse(e.data);
const event = event_json.event; const event = event_json.event;
const data = event_json.data; const data = event_json.data;
if (event == GAME_EVENTS.START_GAME) { if (event == GAME_EVENTS.START_GAME) {
matchmaking = false;
game.start(socket); game.start(socket);
} else if (event == GAME_EVENTS.GAME_TICK) { } else if (event == GAME_EVENTS.GAME_TICK) {
game.update(data); game.update(data);
@ -97,6 +102,12 @@
const data: MatchmakingDto = { matchmaking: false }; const data: MatchmakingDto = { matchmaking: false };
socket.send(formatWebsocketData(GAME_EVENTS.MATCHMAKING, data)); socket.send(formatWebsocketData(GAME_EVENTS.MATCHMAKING, data));
} }
$: {
if (game !== undefined) {
game.updateColors(elementsColor, backgroundColor)
}
}
</script> </script>
<div> <div>
@ -120,11 +131,16 @@
<button on:click={() => (spectateWindow = true)} <button on:click={() => (spectateWindow = true)}
>Spectate a friend</button >Spectate a friend</button
> >
<label for="colorPicker">Elements color:</label>
<ColorPicker bind:color={elementsColor} />
<label for="colorPicker">Background color:</label>
<ColorPicker bind:color={backgroundColor} />
{#if matchmaking} {#if matchmaking}
<div on:click={stopMatchmaking} on:keydown={stopMatchmaking}> <div on:click={stopMatchmaking} on:keydown={stopMatchmaking}>
<Matchmaking {stopMatchmaking} /> <Matchmaking {stopMatchmaking} />
</div> </div>
<button on:click={() => console.log(elementsColor)}>tet</button>
{:else if createMatchWindow} {:else if createMatchWindow}
<div <div
on:click={() => (createMatchWindow = false)} on:click={() => (createMatchWindow = false)}

2
front/volume/src/components/Pong/utils.ts

@ -34,7 +34,7 @@ export class Rect {
draw( draw(
context: CanvasRenderingContext2D, context: CanvasRenderingContext2D,
color: string | CanvasGradient | CanvasPattern color: string
) { ) {
const offset: Point = new Point(this.size.x / 2, this.size.y / 2); const offset: Point = new Point(this.size.x / 2, this.size.y / 2);

Loading…
Cancel
Save