diff --git a/backend/src/socket/socket.gateway.ts b/backend/src/socket/socket.gateway.ts index 6b77d66..67f99ec 100644 --- a/backend/src/socket/socket.gateway.ts +++ b/backend/src/socket/socket.gateway.ts @@ -65,8 +65,8 @@ export class SocketGateway implements OnGatewayConnection, OnGatewayDisconnect { client['userData'] = { ...userData, - x: -25, - y: 400, + x: 800, + y: 800, direction: 'right', state: 'wait', userState: 'on', diff --git a/frontend/src/component/Game/Phaser/Player/myPlayer.ts b/frontend/src/component/Game/Phaser/Player/myPlayer.ts index 652491e..e930f67 100644 --- a/frontend/src/component/Game/Phaser/Player/myPlayer.ts +++ b/frontend/src/component/Game/Phaser/Player/myPlayer.ts @@ -4,6 +4,7 @@ import { changePosition, changeState, calcMoveToPos, + changeDirection, } from '../../util'; import { Player } from './player'; @@ -71,6 +72,9 @@ export class MyPlayer extends Player { const move: any = calcMoveToPos(this, this.heldDirection); this.getBody().setVelocity(move.x * this.speed, move.y * this.speed); + const direction = move.x > 0 ? 'right' : 'left'; + changeDirection(this, direction); + changePosition(this, move.x * this.speed, move.y * this.speed); } else { this.checkAndSetState('wait'); diff --git a/frontend/src/component/Game/Phaser/Player/otherPlayer.ts b/frontend/src/component/Game/Phaser/Player/otherPlayer.ts index a905154..080c86f 100644 --- a/frontend/src/component/Game/Phaser/Player/otherPlayer.ts +++ b/frontend/src/component/Game/Phaser/Player/otherPlayer.ts @@ -1,14 +1,16 @@ -import { changePosition, changeState } from '../../util'; +import { changeDirection, changePosition, changeState } from '../../util'; import { Player } from './player'; export class OtherPlayer extends Player { constructor(scene: Phaser.Scene, data: any) { super(scene, data.x, data.y, data.id, data.characterName, data.nickname); } - update(state: string, x: number, y: number) { + update(state: string, x: number, y: number, direction: string) { const prevState = this.state; this.state = state; + changeDirection(this, direction); + if (this.x !== x || this.y !== y) changePosition(this, x - this.x, y - this.y); if (prevState !== this.state) changeState(this); diff --git a/frontend/src/component/Game/Phaser/Player/player.ts b/frontend/src/component/Game/Phaser/Player/player.ts index 260b73f..5138d43 100644 --- a/frontend/src/component/Game/Phaser/Player/player.ts +++ b/frontend/src/component/Game/Phaser/Player/player.ts @@ -57,7 +57,7 @@ export class Player extends Phaser.Physics.Arcade.Sprite { ); scene.physics.add.existing(this); - this.getBody().setCollideWorldBounds(true).setSize(64, 64); + this.getBody().setCollideWorldBounds(true).setSize(30, 50); changeState(this); } diff --git a/frontend/src/component/Game/game.ts b/frontend/src/component/Game/game.ts index 2a12db5..e71ec89 100644 --- a/frontend/src/component/Game/game.ts +++ b/frontend/src/component/Game/game.ts @@ -46,19 +46,19 @@ export default class Game extends Phaser.Scene { this.myPlayer = new MyPlayer( this, - 400, - 400, + 800, + 800, data.id, data.hair, data.nickname, data.socket ); - const debugGraphics = this.add.graphics().setAlpha(0.7); - this.townLayer.renderDebug(debugGraphics, { - tileColor: null, - collidingTileColor: new Phaser.Display.Color(243, 234, 48, 255), - }); + // const debugGraphics = this.add.graphics().setAlpha(0.7); + // this.townLayer.renderDebug(debugGraphics, { + // tileColor: null, + // collidingTileColor: new Phaser.Display.Color(243, 234, 48, 255), + // }); this.physics.add.collider(this.myPlayer, this.townLayer); @@ -74,6 +74,13 @@ export default class Game extends Phaser.Scene { emitter.on('updateHair', (hair: string) => { this.myPlayer?.updateHair(hair); }); + + window.onclick = (e: MouseEvent) => { + const elem = e.target as HTMLElement; + const checkInput = elem.tagName === 'INPUT'; + + this.input.keyboard.manager.enabled = !checkInput; + }; } preload() { @@ -203,7 +210,8 @@ export default class Game extends Phaser.Scene { const id = data.id.toString().trim(); if (!this.otherPlayer[id]) return; - this.otherPlayer[id].update(data.state, data.x, data.y); + const { state, x, y, direction } = data; + this.otherPlayer[id].update(state, x, y, direction); }); this.socket.on('userLeaved', (data: any) => { diff --git a/frontend/src/component/Game/util.ts b/frontend/src/component/Game/util.ts index b7d8ae0..b3651b7 100644 --- a/frontend/src/component/Game/util.ts +++ b/frontend/src/component/Game/util.ts @@ -15,16 +15,15 @@ export const changeState = (player: any) => { } }; -export const changeDirection = (player: any, moveX: number) => { +export const changeDirection = (player: any, direction: string) => { if (!player.character || !player.hair) return; - if (player.direction === 'left' && moveX <= 0) return; - if (player.direction === 'right' && moveX >= 0) return; + if (player.direction === direction) return; player.character.toggleFlipX(); player.hair.toggleFlipX(); player.dust.toggleFlipX(); - player.direction = player.direction === 'left' ? 'right' : 'left'; + player.direction = direction; }; export const calcMoveToPos = (player: any, dir: string[]) => { @@ -57,8 +56,6 @@ export const changePosition = (player: any, x: number, y: number) => { player.x += x; player.y += y; - changeDirection(player, x); - player.character.setPosition(player.x, player.y); player.hair.setPosition(player.x, player.y); diff --git a/frontend/src/component/SleepyBoard/content.tsx b/frontend/src/component/SleepyBoard/content.tsx index 42c26ce..61a81ad 100644 --- a/frontend/src/component/SleepyBoard/content.tsx +++ b/frontend/src/component/SleepyBoard/content.tsx @@ -1,4 +1,5 @@ -import { useState } from 'react'; +import axios from 'axios'; +import { useEffect, useState } from 'react'; import * as style from './sleepyboard.styled'; import { calcTime } from './util'; @@ -8,13 +9,27 @@ const Content = ({ data }: { data: any }) => { ''; const image = 'http://image.dongascience.com/Photo/2020/03/5bddba7b6574b95d37b6079c199d7101.jpg'; - const { nickname, created_at, category, content } = data; + const { id, nickname, created_at, category, content } = data; const createdDate = calcTime(created_at); - const [isLike, setIsLike] = useState(false); + const [isLike, setIsLike] = useState(''); - const handleLike = () => { - setIsLike(!isLike); + const handleLike = async (e: React.MouseEvent) => { + const elem = e.target as HTMLButtonElement; + if (!elem.dataset.articleid) return; + + const articleId = elem.dataset.articleid; + const value = isLike ? '' : articleId; + + try { + let res; + if (value) res = await axios.put(`/api/board/like/${articleId}`); + else res = await axios.delete(`/api/board/like/${articleId}`); + + if (res.status === 200) setIsLike(value); + } catch (e) { + console.log(e); + } }; return ( @@ -29,9 +44,10 @@ const Content = ({ data }: { data: any }) => {