X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/c6dd514a31a3ddf46b63b4deffc002a03ea714a9..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 3dabef9..84e7b69 100644 --- a/src/main/java/com/codingame/game/View.java +++ b/src/main/java/com/codingame/game/View.java @@ -14,13 +14,12 @@ import com.codingame.gameengine.module.entities.Text; import com.codingame.gameengine.module.entities.TextBasedEntity; import com.codingame.gameengine.module.entities.Group; import com.codingame.gameengine.module.entities.Curve; -import com.codingame.gameengine.module.toggle.ToggleModule; import com.google.inject.Inject; class View { @Inject private MultiplayerGameManager gameManager; @Inject private GraphicEntityModule graphicEntityModule; - @Inject ToggleModule toggleModule; + @Inject PantsModule pantsModule; enum Dir { LEFT("walks left.", 0), @@ -134,9 +133,65 @@ class View { .setFillColor(0xff0080) .setAnchorX(p0 ? 0 : 1) .setAnchorY(0.5); - toggleModule.displayOnToggleState(stoneReminder, "debug", true); + 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) { @@ -177,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(); @@ -346,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 { @@ -406,11 +431,29 @@ class View { .setAnchorX(0.5) .setAnchorY(1) .setTint(trollRace.tint); - Sprite trollPants = graphicEntityModule.createSprite() + Sprite trollPantsRed = graphicEntityModule.createSprite() .setImage("pants_red.png") .setAnchorX(0.5) .setAnchorY(1); - troll = graphicEntityModule.createGroup(trollBody, trollPants) + pantsModule.displayOnPantsState(trollPantsRed, 1); + Sprite trollPantsGreen = graphicEntityModule.createSprite() + .setImage("pants_green.png") + .setAnchorX(0.5) + .setAnchorY(1); + pantsModule.displayOnPantsState(trollPantsGreen, 2); + Sprite trollPantsBlue = graphicEntityModule.createSprite() + .setImage("pants_blue.png") + .setAnchorX(0.5) + .setAnchorY(1); + pantsModule.displayOnPantsState(trollPantsBlue, 3); + Sprite trollPantsPerv = graphicEntityModule.createSprite() + .setImage("pants_perv.png") + .setAnchorX(0.5) + .setAnchorY(1); + pantsModule.displayOnPantsState(trollPantsPerv, 4); + troll = graphicEntityModule + .createGroup(trollBody, trollPantsRed, + trollPantsGreen, trollPantsBlue, trollPantsPerv) .setX(1920/2) .setY(880) .setScaleX(random.nextInt(2) == 0 ? 1 : -1) @@ -425,6 +468,7 @@ class View { moveTroll(); trollMessage = graphicEntityModule.createText() + .setZIndex(1) .setX(1902/2) .setY(680) .setAnchorX(0.5) @@ -433,7 +477,7 @@ class View { .setStrokeColor(0xFFFF00) .setFillColor(0xFFFF00) .setFontSize(40); - toggleModule.displayOnToggleState(trollMessage, "verboseTrolling", true); + pantsModule.displayOnToggleState(trollMessage, "verboseTrolling", true); } private void moveTroll() { @@ -497,7 +541,7 @@ class View { .setY(60) .setAnchorX(0.5) .setLoop(true); - toggleModule.displayOnToggleState(debugMode, "debug", true); + pantsModule.displayOnToggleState(debugMode, "debug", true); turnCounter = graphicEntityModule.createText() .setAnchorX(0.5) @@ -509,7 +553,7 @@ class View { .setFontFamily("monospace") .setFontWeight(Text.FontWeight.BOLD) .setFontSize(100); - toggleModule.displayOnToggleState(turnCounter, "debug", true); + pantsModule.displayOnToggleState(turnCounter, "debug", true); animateTurnCounter(); } @@ -595,6 +639,7 @@ class View { { "Marvel > DC", "Disney > 50 shades", "DC > Marvel" }, { "cats > dogs", "humans make\ngood pets", "dogs > cats" }, { "the moon landing was staged", "elvis lives", "9/11 was an inside job" }, + { "santa claus is really\nthe tooth fairy", "the easter bunny tasted yummy", "the tooth fairy is\nreally santa claus" }, // Ditto. Need moar troll. // gaming @@ -644,6 +689,7 @@ class View { // Those for which I couldn't find a meaningful directednessability. String isotropic[] = { + "(unclosed", "Electron apps are the fastest", "Rosebud", "Thanos did nothing wrong",