Reorganize View/Player
[troll.git] / src / main / java / com / codingame / game / View.java
index 3dabef9..84e7b69 100644 (file)
@@ -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<com.codingame.game.Player> 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",