X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/6ee812987dd1b5e42e23ae463838c4c15a2c3e86..59d8ce65d474d6d46b16cae26ebb6db7cda5c8b2:/src/main/java/com/codingame/game/View.java diff --git a/src/main/java/com/codingame/game/View.java b/src/main/java/com/codingame/game/View.java index 0820190..84e7b69 100644 --- a/src/main/java/com/codingame/game/View.java +++ b/src/main/java/com/codingame/game/View.java @@ -136,6 +136,62 @@ class View { pantsModule.displayOnToggleState(stoneReminder, "debug", true); } + void startTurn() { + graphicEntityModule.commitEntityState(0, stoneReminder); + } + + void victory() { + gameManager.addToGameSummary(GameManager.formatSuccessMessage(nicknameToken + " wins.")); + markWinner(); + } + + void defeat() { + gameManager.addToGameSummary(GameManager.formatErrorMessage(trollRace.starter + " destroys " + nicknameToken + ".")); + destroyCastle(); + } + + // ========== Player/avatar markings + + void markTimeout() { + animateLoss(avatar.getX(), avatar.getY(), 100, "SLOW\nPOKE"); + } + + void markIllegal() { + animateLoss(avatar.getX(), avatar.getY(), 100, "STUPID"); + } + + void markCheat() { + animateLoss(avatar.getX(), avatar.getY(), 100, "CHEATER"); + } + + void markWinner() { + graphicEntityModule.commitEntityState(0.5, avatar); + avatar.setScaleX(1.5, Curve.EASE_OUT); + avatar.setScaleY(1.5, Curve.EASE_OUT); + avatar.setRotation((random.nextDouble() - 0.5) * Math.PI / 18, + Curve.ELASTIC); + } + + void markLoser() { + graphicEntityModule.commitEntityState(0.5, avatar); + int dir = random.nextInt(2) == 1 ? 1 : -1; + avatar.setRotation(dir * 170 * Math.PI / 180, Curve.ELASTIC); + } + + // ==========Player/stones + + void throwStones(int stones) { + gameManager.addToGameSummary(String.format("%s throws %d stone%s at " + trollRace.nonStarter(), nicknameToken, stones, stones == 1 ? "" : "s")); + } + + void threwMoreStonesThanHad() { + gameManager.addToGameSummary(GameManager.formatErrorMessage(nicknameToken + " tried to throw more stones than they had. I'll let it slide for this time. (But not let them throw that much!)")); + } + + void failedToThrowStonesAndShouldHave() { + gameManager.addToGameSummary(GameManager.formatErrorMessage(nicknameToken + " tried not throwing any stones. Fixing that for them because I'm in a good mood today.")); + } + void updateStoneCounter() { int stones = model.getStones(); if (stones <= 0) { @@ -176,61 +232,19 @@ class View { graphicEntityModule.commitEntityState(0, stoneReminder); } + // ========== Player/castle + void displayMessage(String msg) { message.setText(msg); graphicEntityModule.commitEntityState(0, message); } - void markLoser() { - graphicEntityModule.commitEntityState(0.5, avatar); - int dir = random.nextInt(2) == 1 ? 1 : -1; - avatar.setRotation(dir * 170 * Math.PI / 180, Curve.ELASTIC); - } - - void destroy() { - gameManager.addToGameSummary(GameManager.formatErrorMessage(trollRace.starter + " destroys " + nicknameToken + ".")); + void destroyCastle() { graphicEntityModule.commitEntityState(0.5, castle); castle.setX(castle.getX(), Curve.ELASTIC); castle.setScaleY(-0.2, Curve.EASE_IN); } - - void startTurn() { - graphicEntityModule.commitEntityState(0, stoneReminder); - } - - void victory() { - gameManager.addToGameSummary(GameManager.formatSuccessMessage(nicknameToken + " wins.")); - graphicEntityModule.commitEntityState(0.5, avatar); - avatar.setScaleX(1.5, Curve.EASE_OUT); - avatar.setScaleY(1.5, Curve.EASE_OUT); - avatar.setRotation((random.nextDouble() - 0.5) * Math.PI / 18, - Curve.ELASTIC); - } - - void throwStones(int stones) { - gameManager.addToGameSummary(String.format("%s throws %d stone%s at " + trollRace.nonStarter(), nicknameToken, stones, stones == 1 ? "" : "s")); - } - - void threwMoreStonesThanHad() { - gameManager.addToGameSummary(GameManager.formatErrorMessage(nicknameToken + " tried to throw more stones than they had. I'll let it slide for this time. (But not let them throw that much!)")); - } - - void failedToThrowStonesAndShouldHave() { - gameManager.addToGameSummary(GameManager.formatErrorMessage(nicknameToken + " tried not throwing any stones. Fixing that for them because I'm in a good mood today.")); - } - - void markTimeout() { - animateLoss(avatar.getX(), avatar.getY(), 100, "SLOW\nPOKE"); - } - - void markIllegal() { - animateLoss(avatar.getX(), avatar.getY(), 100, "STUPID"); - } - - void markCheat() { - animateLoss(avatar.getX(), avatar.getY(), 100, "CHEATER"); - } - } + } // class Player Model model; Random random = new Random(); @@ -345,6 +359,18 @@ class View { .setSkewX((random.nextDouble() - 0.5) /4) .setSkewY((random.nextDouble() - 0.5) /8); } + + // base png: 514×387 + Sprite f7u12 = graphicEntityModule.createSprite() + .setImage("f7u12.png") + .setX(1920 / 2) + .setY(1080 / 2) + .setAnchorX(0.5) + .setAnchorY(0.5) + .setBaseWidth(514*1080/387) + .setBaseHeight(1080) + .setZIndex(200); + pantsModule.displayOnToggleState(f7u12, "troll", true); } enum TrollRace { @@ -442,6 +468,7 @@ class View { moveTroll(); trollMessage = graphicEntityModule.createText() + .setZIndex(1) .setX(1902/2) .setY(680) .setAnchorX(0.5)