X-Git-Url: https://troll.desast.re/troll.git/blobdiff_plain/9e6c50a065afce798eedf02c7a6dbfe3c4f3b91a..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 45b4401..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("Troll 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 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(); @@ -346,19 +359,101 @@ 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 { + 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() { + 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) - .setTint(0xfac200); - Sprite trollPants = graphicEntityModule.createSprite() + .setTint(trollRace.tint); + 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) @@ -373,6 +468,7 @@ class View { moveTroll(); trollMessage = graphicEntityModule.createText() + .setZIndex(1) .setX(1902/2) .setY(680) .setAnchorX(0.5) @@ -381,7 +477,7 @@ class View { .setStrokeColor(0xFFFF00) .setFillColor(0xFFFF00) .setFontSize(40); - toggleModule.displayOnToggleState(trollMessage, "verboseTrolling", true); + pantsModule.displayOnToggleState(trollMessage, "verboseTrolling", true); } private void moveTroll() { @@ -411,7 +507,7 @@ class View { 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); @@ -445,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) @@ -457,7 +553,7 @@ class View { .setFontFamily("monospace") .setFontWeight(Text.FontWeight.BOLD) .setFontSize(100); - toggleModule.displayOnToggleState(turnCounter, "debug", true); + pantsModule.displayOnToggleState(turnCounter, "debug", true); 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" }, + { "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 @@ -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" }, + { "santa claus is really\nthe tooth fairy", "the easter bunny tasted yummy", "the tooth fairy is\nreally santa claus" }, // 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" }, + { "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 @@ -574,6 +675,9 @@ class View { // 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" }, @@ -585,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", @@ -592,7 +697,6 @@ class View { "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"