DEV: Player has a champion flag to indicate the supply pickup ability
This commit is contained in:
		
							parent
							
								
									f1e7235253
								
							
						
					
					
						commit
						524988079f
					
				| @ -395,8 +395,11 @@ class Board { | ||||
|       int S = tiles[tileId].hasSupply(supplies); | ||||
| 
 | ||||
|       if      (T && !M)    return " T "; | ||||
|       else if (M && !T)    return " M "; | ||||
|       else if (T && M)     return "T+M"; | ||||
|       else if (M) { | ||||
|          if (S == Const.noSupply)   return " M "; | ||||
|          else                       return "M+s"; | ||||
|       } | ||||
|       else if (S != Const.noSupply) | ||||
|          return String.format("s%02d", S+1); | ||||
|       else                 return "   "; | ||||
|  | ||||
| @ -7,17 +7,38 @@ | ||||
| 
 | ||||
| package net.hoo2.auth.labyrinth; | ||||
| 
 | ||||
| import java.util.Scanner; | ||||
| 
 | ||||
| /** | ||||
|  * Main application class. This class is the only public interface of | ||||
|  * the entire game. | ||||
|  */ | ||||
| public class Game { | ||||
| 
 | ||||
|    Game() {}   /**< An empty constructor */ | ||||
|    /**< An empty constructor */ | ||||
|    Game() { | ||||
|       scan = new Scanner(System.in); | ||||
|    } | ||||
| 
 | ||||
|    /** @name Player main application interface */ | ||||
|    /** @{ */ | ||||
|    /** Utility to get current round of the game */ | ||||
|    int round ()      { return round; } | ||||
|    /** Utility to increase and get the increased round of the game */ | ||||
|    int nextRound()   { return ++round; } | ||||
| 
 | ||||
|    /** | ||||
|     *  Utility to hold the execution of the program waiting for user input. | ||||
|     *  This is true only if the user passed the interactive flag. | ||||
|     */ | ||||
|    void waitUser () { | ||||
|       if(Session.interactive) { | ||||
|          System.out.println("Press enter to continue..."); | ||||
|          scan.nextLine(); | ||||
|       } | ||||
|    } | ||||
|    /** @{ */ | ||||
| 
 | ||||
|    /** | ||||
|     * @name Accessor/Mutator interface | ||||
|     * @note | ||||
| @ -31,15 +52,14 @@ public class Game { | ||||
| 
 | ||||
|    /** @name Game's data */ | ||||
|    /** @{ */ | ||||
|    private int round; | ||||
|    private int round;      /**< Holds the round of the game */ | ||||
|    private Scanner scan;   /**< Input handle used in interactive mode */ | ||||
|    /** @} */ | ||||
| 
 | ||||
|    /** | ||||
|     * Main game loop | ||||
|     * Command line argument handler | ||||
|     */ | ||||
|    static boolean getArguments (String[] args) { | ||||
|       boolean ret = true; | ||||
| 
 | ||||
|       for (int i =0 ; i<args.length ; ++i) { | ||||
|          switch (args[i]) { | ||||
|             case "-b": | ||||
| @ -61,7 +81,6 @@ public class Game { | ||||
|                break; | ||||
| 
 | ||||
|             default: | ||||
|                ret = false; | ||||
|             case "-h": | ||||
|             case "--help": | ||||
|                System.out.println("Labyrinth Game"); | ||||
| @ -78,13 +97,17 @@ public class Game { | ||||
|                break; | ||||
|          } | ||||
|       } | ||||
|       return ret; | ||||
|       return true; | ||||
|    } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Main game loop | ||||
|     */ | ||||
|    public static void main(String[] args) { | ||||
|       try { | ||||
|          // Get command line options | ||||
|          Game.getArguments(args); | ||||
|          if (!Game.getArguments(args)) throw new Exception(""); | ||||
| 
 | ||||
|          // Create a game, a board and 2 players. | ||||
|          Game game   = new Game(); | ||||
| @ -95,12 +118,19 @@ public class Game { | ||||
|          // Populate data to the board | ||||
|          board.createBoard(T.playerTileId(), M.playerTileId()); | ||||
| 
 | ||||
|          // The game | ||||
|          // Initial board printout | ||||
|          System.out.println("Initial board: " + (game.round())); | ||||
|          board.printBoard( | ||||
|                board.getStringRepresentation(T.playerTileId(), M.playerTileId()) | ||||
|          ); | ||||
|          game.waitUser (); | ||||
|          // Main game loop | ||||
|          while (true) { | ||||
|             int[] m; | ||||
|             System.out.println(); | ||||
|             System.out.println("Round: " + (game.round()+1)); | ||||
|             System.out.println("State after round: " + (game.round()+1)); | ||||
| 
 | ||||
|             // Player moves | ||||
|             m = T.move(T.playerTileId()); | ||||
|                System.out.println(T.getName() + ":\t tileId =" + m[0] + " (" + m[1] + ", " + m[2] + ")"); | ||||
|             m = M.move(M.playerTileId()); | ||||
| @ -109,7 +139,7 @@ public class Game { | ||||
|                   board.getStringRepresentation(T.playerTileId(), M.playerTileId()) | ||||
|             ); | ||||
| 
 | ||||
|             // Termination cases | ||||
|             // Loop termination cases | ||||
|             if (T.getScore() == 4) { | ||||
|                System.out.println(T.getName() + " Wins!!! Score =" + T.getScore()); | ||||
|                System.exit(0); | ||||
| @ -118,13 +148,15 @@ public class Game { | ||||
|                System.out.println(M.getName() + " Wins!!! Score =" + M.getScore()); | ||||
|                System.exit(0); | ||||
|             } | ||||
|             if (!(game.nextRound() < 100)) { | ||||
|             if (!(game.nextRound() < Session.maxRounds)) { | ||||
|                System.out.println("New day has come... Tie!!!"); | ||||
|                System.exit(0); | ||||
|             } | ||||
|             game.waitUser (); | ||||
|          } | ||||
|       } | ||||
|       catch (Exception e) { | ||||
|          // We don't handle exceptions. Print error and exit with error status. | ||||
|          System.out.println(e.getMessage()); | ||||
|          System.exit(1); | ||||
|       } | ||||
|  | ||||
| @ -6,7 +6,7 @@ package net.hoo2.auth.labyrinth; | ||||
|  *    This class represents the game's player | ||||
|  */ | ||||
| class Player { | ||||
|    /** @name Contructors */ | ||||
|    /** @name Constructors */ | ||||
|    /** @{ */ | ||||
| 
 | ||||
|    /** | ||||
| @ -15,13 +15,14 @@ class Player { | ||||
|     * @param name    The name of the player | ||||
|     * @param board   Reference to the board of the game | ||||
|     */ | ||||
|    Player(int id, String name, Board board, int row, int column) { | ||||
|    Player(int id, String name, boolean champion, Board board, int row, int column) { | ||||
|       this.playerId  = id; | ||||
|       this.name      = name; | ||||
|       this.board     = board; | ||||
|       this.score     = 0; | ||||
|       this.x         = column; | ||||
|       this.y         = row; | ||||
|       this.champion  = champion; | ||||
|    } | ||||
| 
 | ||||
|    /** | ||||
| @ -30,13 +31,14 @@ class Player { | ||||
|     * @param name    The name of the player | ||||
|     * @param board   Reference to the board of the game | ||||
|     */ | ||||
|    Player(int id, String name, Board board, int tileId) { | ||||
|    Player(int id, String name, boolean champion, Board board, int tileId) { | ||||
|       this.playerId  = id; | ||||
|       this.name      = name; | ||||
|       this.board     = board; | ||||
|       this.score     = 0; | ||||
|       this.x         = Position.toCol(tileId); | ||||
|       this.y         = Position.toRow(tileId); | ||||
|       this.champion  = champion; | ||||
|    } | ||||
|    /** @} */ | ||||
| 
 | ||||
| @ -46,9 +48,9 @@ class Player { | ||||
|    /** | ||||
|     * Player's move. | ||||
|     * | ||||
|     * A player first throw a dice to get a random direction. Then checks if the direction | ||||
|     * is walkable. If it is, then goes to that tile, pick up a possible supply on the tile | ||||
|     * and update player's data. | ||||
|     * A player first throws a dice to get a random direction. Then checks if the direction | ||||
|     * is walkable. If it is, then goes to that tile and update player's data. | ||||
|     * If the player is a champion then he also picks up a possible supply from the tile. | ||||
|     * | ||||
|     * @param id   The id of the starting tile. | ||||
|     * @return     An array containing player's final position and possible supply of that position. | ||||
| @ -61,7 +63,7 @@ class Player { | ||||
|     * </ul> | ||||
|     */ | ||||
|    int[] move(int id) { | ||||
|       // Init return array with the current data | ||||
|       // Initialize return array with the current data | ||||
|       int[] ret = {id, Position.toRow(id), Position.toCol(id), Const.noSupply}; | ||||
| 
 | ||||
|       int diceDirection = board.dice();            // throw the dice | ||||
| @ -71,7 +73,8 @@ class Player { | ||||
|          ret[0] = next.getId();                    // Update player's and return data | ||||
|          ret[1] = y = next.getRow(); | ||||
|          ret[2] = x = next.getCol(); | ||||
|          if ((ret[3] = board.tryPickSupply(next.getId())) != Const.noSupply) { | ||||
|          // In case of a champion player, try also to pick a supply | ||||
|          if (champion && (ret[3] = board.tryPickSupply(next.getId())) != Const.noSupply) { | ||||
|             ++score;                               // keep score | ||||
|             System.out.println(name + ":\t*Found a supply. [score: " + score + "]"); | ||||
|          } | ||||
| @ -81,8 +84,11 @@ class Player { | ||||
|       return ret; | ||||
|    } | ||||
| 
 | ||||
|    /** Utility to access player's tileID */ | ||||
|    int playerTileId()   { return Position.toID(y, x); } | ||||
|    /** Utility to access player's row position (row coordinate) */ | ||||
|    int playerRow()      { return y; } | ||||
|    /** Utility to access player's column position (column coordinate) */ | ||||
|    int playerCol()      { return x; } | ||||
|    /** @} */ | ||||
| 
 | ||||
| @ -122,5 +128,6 @@ class Player { | ||||
|    private int    score;      /**< The current score of the player */ | ||||
|    private int    x;          /**< The column coordinate of the player on the board */ | ||||
|    private int    y;          /**< The row coordinate of the player on the board */ | ||||
|    private boolean champion;  /**< Champion indicate a player who plays against the Minotaur */ | ||||
|    /** @} */ | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user