From 76b426bdb9cc629412ddaa44c5e4095732398a5a Mon Sep 17 00:00:00 2001 From: yhpark95 <98851575+yhpark95@users.noreply.github.com> Date: Thu, 2 Nov 2023 13:44:03 +0900 Subject: [PATCH 1/4] =?UTF-8?q?feat:=20=EC=88=9C=EA=B0=84=EC=9D=B4?= =?UTF-8?q?=EB=8F=99=20=EC=9D=91=EB=8B=B5=20=EC=B6=94=EA=B0=80=20#69?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../game/controller/GameController.java | 3 +++ .../game/dto/response/GameTeleportResponse.java | 14 ++++++++++++++ 2 files changed, 17 insertions(+) create mode 100644 be/src/main/java/codesquad/gaemimarble/game/dto/response/GameTeleportResponse.java diff --git a/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java b/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java index fa92bc7..53e5e2f 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java +++ b/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java @@ -30,6 +30,7 @@ import codesquad.gaemimarble.game.dto.response.GameCellResponse; import codesquad.gaemimarble.game.dto.response.GameEventNameResponse; import codesquad.gaemimarble.game.dto.response.GameRoomCreateResponse; +import codesquad.gaemimarble.game.dto.response.GameTeleportResponse; import codesquad.gaemimarble.game.dto.response.userStatusBoard.GameUserBoardResponse; import codesquad.gaemimarble.game.entity.Player; import codesquad.gaemimarble.game.entity.TypeConstants; @@ -167,6 +168,8 @@ private void sendCellArrival(Long gameId, String playerId) { private void sendTeleport(GameTeleportRequest gameTeleportRequest) { gameService.teleport(gameTeleportRequest); sendCellArrival(gameTeleportRequest.getGameId(), gameTeleportRequest.getPlayerId()); + socketDataSender.send(gameTeleportRequest.getGameId(), new ResponseDTO<>(TypeConstants.TELEPORT, + GameTeleportResponse.builder().location(gameTeleportRequest.getLocation()).build())); } private void sendRandomEvents(GameEventRequest gameEventRequest) { diff --git a/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameTeleportResponse.java b/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameTeleportResponse.java new file mode 100644 index 0000000..2943999 --- /dev/null +++ b/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameTeleportResponse.java @@ -0,0 +1,14 @@ +package codesquad.gaemimarble.game.dto.response; + +import lombok.Builder; +import lombok.Getter; + +@Getter +public class GameTeleportResponse { + private final Integer location; + + @Builder + private GameTeleportResponse(Integer location) { + this.location = location; + } +} From cbf23a81dc6c418bc104e1b53bbc0b04f37be2c1 Mon Sep 17 00:00:00 2001 From: yhpark95 <98851575+yhpark95@users.noreply.github.com> Date: Thu, 2 Nov 2023 13:56:08 +0900 Subject: [PATCH 2/4] =?UTF-8?q?fix:=20=EC=A3=BC=EC=82=AC=EC=9C=84=20?= =?UTF-8?q?=EA=B2=B0=EA=B3=BC=206=EC=9D=84=20=EA=B3=A0=EC=A0=95=20X=20#69?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../codesquad/gaemimarble/game/service/GameService.java | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java index e0b4ca9..25ff45c 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java +++ b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java @@ -110,10 +110,8 @@ public GameDiceResult rollDice(Long gameId, String playerId) { Player player = gameStatus.getPlayer(playerId); int startLocation = player.getLocation(); - // int dice1 = (int)(Math.random() * 6) + 1; - // int dice2 = (int)(Math.random() * 6) + 1; - int dice1 = 4; - int dice2 = 2; + int dice1 = (int)(Math.random() * 6) + 1; + int dice2 = (int)(Math.random() * 6) + 1; if (dice1 == dice2) { int countDouble = gameStatus.getCurrentPlayerInfo().increaseCountDouble(); From 7514f0b233d7dd6fa26e138928bbe45f17fec8e3 Mon Sep 17 00:00:00 2001 From: yhpark95 <98851575+yhpark95@users.noreply.github.com> Date: Thu, 2 Nov 2023 14:06:43 +0900 Subject: [PATCH 3/4] =?UTF-8?q?fix:=20=EC=A3=BC=EC=8B=9D=EA=B0=80=EA=B2=A9?= =?UTF-8?q?=200=EC=9C=BC=EB=A1=9C=20=EB=A6=AC=EB=AF=B8=ED=8A=B8,=20?= =?UTF-8?q?=EA=B0=90=EC=98=A5=20=EC=88=9C=EA=B0=84=EC=9D=B4=EB=8F=99=20?= =?UTF-8?q?=EB=8F=84=EC=B0=A9=EC=8B=9C=20=EB=8B=A4=EC=9D=8C=20=ED=94=8C?= =?UTF-8?q?=EB=A0=88=EC=9D=B4=EC=96=B4=20=EC=B0=A8=EB=A1=80=EB=A1=9C=20?= =?UTF-8?q?=EB=B3=80=EA=B2=BD=EB=90=98=EA=B2=8C=20=EC=88=98=EC=A0=95=20#69?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/codesquad/gaemimarble/game/entity/Stock.java | 5 +++++ .../java/codesquad/gaemimarble/game/service/GameService.java | 5 ++++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/be/src/main/java/codesquad/gaemimarble/game/entity/Stock.java b/be/src/main/java/codesquad/gaemimarble/game/entity/Stock.java index eb65e56..d54cf8d 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/entity/Stock.java +++ b/be/src/main/java/codesquad/gaemimarble/game/entity/Stock.java @@ -41,6 +41,11 @@ public static List initStocks() { } public void changePrice(Integer percentage) { + Integer changingPrice = this.currentPrice + ((this.startPrice * percentage) / 100); + if (changingPrice <= 0) { + currentPrice = 0; + return; + } this.currentPrice += ((this.startPrice * percentage) / 100); } diff --git a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java index 25ff45c..2763e93 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java +++ b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java @@ -301,7 +301,10 @@ public GameEndTurnResponse endTurn(GameEndTurnRequest gameEndTurnRequest) { if (currentPlayerInfo.getRolledDouble()) { currentPlayerInfo.initRolledDouble(); - return GameEndTurnResponse.builder().nextPlayerId(currentPlayerInfo.getPlayerId()).build(); + Integer location = gameStatus.getPlayer(currentPlayerInfo.getPlayerId()).getLocation(); + if (!(location == 18 || location == 6)) { + return GameEndTurnResponse.builder().nextPlayerId(currentPlayerInfo.getPlayerId()).build(); + } } if (currentPlayerInfo.getOrder() != gameStatus.getPlayers().size()) { From f7becd4ee545691c92231e25bac95c81a307474a Mon Sep 17 00:00:00 2001 From: yhpark95 <98851575+yhpark95@users.noreply.github.com> Date: Thu, 2 Nov 2023 14:29:22 +0900 Subject: [PATCH 4/4] =?UTF-8?q?fix:=20=EC=84=B8=EB=B2=88=20=EB=8D=94?= =?UTF-8?q?=EB=B8=94=20=EC=8B=9C=20=EA=B0=90=EC=98=A5=EC=9C=BC=EB=A1=9C=20?= =?UTF-8?q?=EC=88=9C=EA=B0=84=EC=9D=B4=EB=8F=99=20#69?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../gaemimarble/game/controller/GameController.java | 9 ++++++++- .../gaemimarble/game/dto/response/GameDiceResult.java | 6 +++--- .../codesquad/gaemimarble/game/service/GameService.java | 4 ++-- 3 files changed, 13 insertions(+), 6 deletions(-) diff --git a/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java b/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java index 53e5e2f..eb6a430 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java +++ b/be/src/main/java/codesquad/gaemimarble/game/controller/GameController.java @@ -28,6 +28,7 @@ import codesquad.gaemimarble.game.dto.request.GameTeleportRequest; import codesquad.gaemimarble.game.dto.response.GameAccessibleResponse; import codesquad.gaemimarble.game.dto.response.GameCellResponse; +import codesquad.gaemimarble.game.dto.response.GameDiceResult; import codesquad.gaemimarble.game.dto.response.GameEventNameResponse; import codesquad.gaemimarble.game.dto.response.GameRoomCreateResponse; import codesquad.gaemimarble.game.dto.response.GameTeleportResponse; @@ -153,8 +154,14 @@ private void sendFirstPlayer(GameStartRequest gameStartRequest) { } private void sendDiceResult(GameRollDiceRequest gameRollDiceRequest) { + GameDiceResult gameDiceResult = gameService.rollDice(gameRollDiceRequest.getGameId(), + gameRollDiceRequest.getPlayerId()); socketDataSender.send(gameRollDiceRequest.getGameId(), new ResponseDTO<>(TypeConstants.DICE, - gameService.rollDice(gameRollDiceRequest.getGameId(), gameRollDiceRequest.getPlayerId()))); + gameDiceResult)); + if (gameDiceResult.getTripleDouble()) { + socketDataSender.send(gameRollDiceRequest.getGameId(), new ResponseDTO<>(TypeConstants.TELEPORT, + GameTeleportResponse.builder().location(6).build())); + } sendCellArrival(gameRollDiceRequest.getGameId(), gameRollDiceRequest.getPlayerId()); } diff --git a/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameDiceResult.java b/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameDiceResult.java index a8c8a94..c17f727 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameDiceResult.java +++ b/be/src/main/java/codesquad/gaemimarble/game/dto/response/GameDiceResult.java @@ -7,13 +7,13 @@ @Getter @NoArgsConstructor public class GameDiceResult { - private Integer startLocation; + private Boolean tripleDouble; private Integer dice1; private Integer dice2; @Builder - public GameDiceResult(Integer startLocation, Integer dice1, Integer dice2) { - this.startLocation = startLocation; + public GameDiceResult(Boolean tripleDouble, Integer dice1, Integer dice2) { + this.tripleDouble = tripleDouble; this.dice1 = dice1; this.dice2 = dice2; } diff --git a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java index 2763e93..53485cc 100644 --- a/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java +++ b/be/src/main/java/codesquad/gaemimarble/game/service/GameService.java @@ -118,11 +118,11 @@ public GameDiceResult rollDice(Long gameId, String playerId) { if (countDouble == 3) { player.goToPrison(); - return new GameDiceResult(startLocation, dice1, dice2); + return new GameDiceResult(true, dice1, dice2); } } player.move(dice1 + dice2); - return new GameDiceResult(startLocation, dice1, dice2); + return new GameDiceResult(false, dice1, dice2); } public GameCellResponse arriveAtCell(Long gameId, String playerId) {