+ 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."));