Reorganize View/Player
[troll.git] / src / main / java / com / codingame / game / View.java
index 45b4401..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.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;
 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),
 
     enum Dir {
         LEFT("walks left.", 0),
@@ -134,9 +133,65 @@ class View {
                 .setFillColor(0xff0080)
                 .setAnchorX(p0 ? 0 : 1)
                 .setAnchorY(0.5);
                 .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) {
         void updateStoneCounter() {
             int stones = model.getStones();
             if (stones <= 0) {
@@ -177,61 +232,19 @@ class View {
             graphicEntityModule.commitEntityState(0, stoneReminder);
         }
 
             graphicEntityModule.commitEntityState(0, stoneReminder);
         }
 
+        // ========== Player/castle
+        
         void displayMessage(String msg) {
             message.setText(msg);
             graphicEntityModule.commitEntityState(0, message);
         }
 
         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("Troll destroys " + nicknameToken + "."));
+        void destroyCastle() {
             graphicEntityModule.commitEntityState(0.5, castle);
             castle.setX(castle.getX(), Curve.ELASTIC);
             castle.setScaleY(-0.2, Curve.EASE_IN);
         }
             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 the troll.", 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();
 
     Model model;
     Random random = new Random();
@@ -346,19 +359,101 @@ class View {
                 .setSkewX((random.nextDouble() - 0.5) /4)
                 .setSkewY((random.nextDouble() - 0.5) /8);
         }
                 .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 {
+        Troll("The troll", 0xfac200, "bland"),
+        IceTroll("The ice troll", 0x59a2a2, "ice"),
+        RockTroll("The rock troll", 0x78877f, "rock"),
+        WaterTroll("The water troll", 0x2b2fc6, "water"),
+        OlogHai("The Olog-Hai", 0x5b2e7d, "ologhai");
+        String starter, parser; int tint;
+        TrollRace(String s, int t, String p) {
+            starter = s;
+            tint = t;
+            parser = p;
+        }
+        String nonStarter() {
+            return Character.toLowerCase(starter.charAt(0))
+                + starter.substring(1);
+        }
     }
     }
+    TrollRace trollRace;
 
     private void drawTroll() {
 
     private void drawTroll() {
+        int r, league = gameManager.getLeagueLevel();
+        if (league <= 1) r = 4;
+        else if (league <= 2) r = 8;
+        else r = 10;
+
+        r = random.nextInt(r);
+        if (r < 4) trollRace = TrollRace.Troll;
+        else if (r < 6) trollRace = TrollRace.IceTroll;
+        else if (r < 8) trollRace = TrollRace.RockTroll;
+        else if (r < 9) trollRace = TrollRace.WaterTroll;
+        else if (r < 10) trollRace = TrollRace.OlogHai;
+        else throw new RuntimeException("Internal error: unknown troll race " + r);
+
+        // We read it for debugging purposes, but don't echo it back
+        // to the IDE.  It is, after all, *not* a map parameter!
+        String buf = gameManager.getGameParameters().getProperty("ehtnicity");
+        if (buf != null) {
+            String key = "";
+            for (char c : buf.toCharArray())
+                if (Character.isLetter(c))
+                    key += Character.toLowerCase(c);
+            iHateJava: do {
+                for (TrollRace race : TrollRace.values()) {
+                    if (key.equals(race.parser)) {
+                        trollRace = race;
+                        break/*ing news: */ iHateJava;
+                    }
+                }
+                gameManager.addToGameSummary("Ignoring unknown troll race: " + buf);
+            } while (false);
+        }
+        photoFinish: ; // The race is through, but Java has no goto :-(
+
         Sprite trollBody = graphicEntityModule.createSprite()
             .setImage("troll_body.png")
             .setAnchorX(0.5)
             .setAnchorY(1)
         Sprite trollBody = graphicEntityModule.createSprite()
             .setImage("troll_body.png")
             .setAnchorX(0.5)
             .setAnchorY(1)
-            .setTint(0xfac200);
-        Sprite trollPants = graphicEntityModule.createSprite()
+            .setTint(trollRace.tint);
+        Sprite trollPantsRed = graphicEntityModule.createSprite()
             .setImage("pants_red.png")
             .setAnchorX(0.5)
             .setAnchorY(1);
             .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)
             .setX(1920/2)
             .setY(880)
             .setScaleX(random.nextInt(2) == 0 ? 1 : -1)
@@ -373,6 +468,7 @@ class View {
         moveTroll();
 
         trollMessage = graphicEntityModule.createText()
         moveTroll();
 
         trollMessage = graphicEntityModule.createText()
+            .setZIndex(1)
             .setX(1902/2)
             .setY(680)
             .setAnchorX(0.5)
             .setX(1902/2)
             .setY(680)
             .setAnchorX(0.5)
@@ -381,7 +477,7 @@ class View {
             .setStrokeColor(0xFFFF00)
             .setFillColor(0xFFFF00)
             .setFontSize(40);
             .setStrokeColor(0xFFFF00)
             .setFillColor(0xFFFF00)
             .setFontSize(40);
-        toggleModule.displayOnToggleState(trollMessage, "verboseTrolling", true);
+        pantsModule.displayOnToggleState(trollMessage, "verboseTrolling", true);
     }
 
     private void moveTroll() {
     }
 
     private void moveTroll() {
@@ -411,7 +507,7 @@ class View {
 
     void moveTroll(Dir d) {
         moveTroll();
 
     void moveTroll(Dir d) {
         moveTroll();
-        gameManager.addToGameSummary("Troll " + d.movement);
+        gameManager.addToGameSummary(trollRace.starter + " " + d.movement);
 
         trollMessage.setText(selectTrollMessage(d)).setAlpha(1, Curve.NONE);
         graphicEntityModule.commitEntityState(0.5, trollMessage);
 
         trollMessage.setText(selectTrollMessage(d)).setAlpha(1, Curve.NONE);
         graphicEntityModule.commitEntityState(0.5, trollMessage);
@@ -445,7 +541,7 @@ class View {
             .setY(60)
             .setAnchorX(0.5)
             .setLoop(true);
             .setY(60)
             .setAnchorX(0.5)
             .setLoop(true);
-        toggleModule.displayOnToggleState(debugMode, "debug", true);
+        pantsModule.displayOnToggleState(debugMode, "debug", true);
 
         turnCounter = graphicEntityModule.createText()
             .setAnchorX(0.5)
 
         turnCounter = graphicEntityModule.createText()
             .setAnchorX(0.5)
@@ -457,7 +553,7 @@ class View {
             .setFontFamily("monospace")
             .setFontWeight(Text.FontWeight.BOLD)
             .setFontSize(100);
             .setFontFamily("monospace")
             .setFontWeight(Text.FontWeight.BOLD)
             .setFontSize(100);
-        toggleModule.displayOnToggleState(turnCounter, "debug", true);
+        pantsModule.displayOnToggleState(turnCounter, "debug", true);
         animateTurnCounter();
     }
 
         animateTurnCounter();
     }
 
@@ -531,6 +627,7 @@ class View {
         // movies
         { "Han shot first", "I am your father", "Greedo shot first" },
         { "Inception ends\non level zero", "BRAAAAAAM", "Inception ends\non level one" },
         // movies
         { "Han shot first", "I am your father", "Greedo shot first" },
         { "Inception ends\non level zero", "BRAAAAAAM", "Inception ends\non level one" },
+        { "star wars > star trek", "my god, it's full of troll", "star trek > star wars" },
         // More movie controversies sought.  Apply on the puzzle contrib page.
 
         // music
         // More movie controversies sought.  Apply on the puzzle contrib page.
 
         // music
@@ -542,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" },
         { "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
         // Ditto.  Need moar troll.
 
         // gaming
@@ -550,6 +648,9 @@ class View {
         { "pad > stick", "mouse gaming is lame", "stick > pad" },
         { "RTS > FPS", "solitaire best game", "FPS > RTS" },
         { "YT gaming > twitch", "i watch other ppl play", "twitch > YT gaming" },
         { "pad > stick", "mouse gaming is lame", "stick > pad" },
         { "RTS > FPS", "solitaire best game", "FPS > RTS" },
         { "YT gaming > twitch", "i watch other ppl play", "twitch > YT gaming" },
+        { "orcs are wusses", "the amulet is in another dungeon", "elves are wusses" },
+        { "here's a link to my patreon", "my apm > yours", "here's my soundcloud" },
+        { "all your stones is belong to us", "all your castle are belong to us", "all your rocks is belong to us" },
         // I'm not exactly a gamer myself, I take hints on the topics du jour
 
         // programming
         // I'm not exactly a gamer myself, I take hints on the topics du jour
 
         // programming
@@ -574,6 +675,9 @@ class View {
         // More always welcome here.
 
         // CodinGame
         // More always welcome here.
 
         // CodinGame
+        { "my nn is in python", "my language has -O3", "my code is more than 100k" },
+        { "i found a bug\nin temperatures", "i found a bug on\nthe leaderboard", "i found a bug\nin chuck norris" },
+        { "fix it", "how is ur csb", "ezpz" },
         { "searcho no chokudai", "GAimax is True AI", "Smitsimax FTW" },
         { "Automaton2000 > NN", "bots > humans", "AutomatonNN > 2000" },
         { "optimizing for the contest\ntestcase is cheating", "having moar accounts than cg\nstaff will get you banned", "it's not hardcoding\nif it's stochastic" },
         { "searcho no chokudai", "GAimax is True AI", "Smitsimax FTW" },
         { "Automaton2000 > NN", "bots > humans", "AutomatonNN > 2000" },
         { "optimizing for the contest\ntestcase is cheating", "having moar accounts than cg\nstaff will get you banned", "it's not hardcoding\nif it's stochastic" },
@@ -585,6 +689,7 @@ class View {
 
     // Those for which I couldn't find a meaningful directednessability.
     String isotropic[] = {
 
     // Those for which I couldn't find a meaningful directednessability.
     String isotropic[] = {
+        "(unclosed",
         "Electron apps are the fastest",
         "Rosebud",
         "Thanos did nothing wrong",
         "Electron apps are the fastest",
         "Rosebud",
         "Thanos did nothing wrong",
@@ -592,7 +697,6 @@ class View {
         "the cloud is just\nother ppl's computers",
         "ur doin it rong",
         "tortue",
         "the cloud is just\nother ppl's computers",
         "ur doin it rong",
         "tortue",
-        "how is ur csb",
         "31OCT = 25DEC",
         "ASCII stupid question\nget a stupid ANSI",
         "trolling is a art"
         "31OCT = 25DEC",
         "ASCII stupid question\nget a stupid ANSI",
         "trolling is a art"