author | Jens Alfke <jens@mooseyard.com> |
Tue Jul 07 08:44:33 2009 -0700 (2009-07-07) | |
changeset 28 | 06160a812d43 |
parent 12 | 4e567e11f45f |
permissions | -rw-r--r-- |
jens@10 | 1 |
// |
jens@10 | 2 |
// Game+Protected.h |
jens@10 | 3 |
// YourMove |
jens@10 | 4 |
// |
jens@10 | 5 |
// Created by Jens Alfke on 7/3/08. |
jens@10 | 6 |
// Copyright 2008 Jens Alfke. All rights reserved. |
jens@10 | 7 |
// |
jens@10 | 8 |
|
jens@10 | 9 |
|
jens@10 | 10 |
#import "Game.h" |
jens@10 | 11 |
#import "Player.h" |
jens@10 | 12 |
#import "Turn.h" |
jens@10 | 13 |
#import "Bit.h" |
jens@10 | 14 |
#import "BitHolder.h" |
jens@12 | 15 |
@class Piece; |
jens@10 | 16 |
|
jens@10 | 17 |
|
jens@10 | 18 |
/** Game API for subclasses to use / override */ |
jens@10 | 19 |
@interface Game (Protected) |
jens@10 | 20 |
|
jens@10 | 21 |
/** Should return a string describing the initial state of a new game. |
jens@10 | 22 |
The default value is an empty string. */ |
jens@10 | 23 |
- (NSString*) initialStateString; |
jens@10 | 24 |
|
jens@10 | 25 |
|
jens@10 | 26 |
#pragma mark Abstract methods for subclasses to implement: |
jens@10 | 27 |
|
jens@22 | 28 |
/** Called by -setTable: Should all all necessary Grids/Pieces/Cards/etc. to _table. |
jens@10 | 29 |
This method is always called during initialization of a new Game, and may be called |
jens@22 | 30 |
again afterwards, for example if the table area is resized. */ |
jens@10 | 31 |
- (void) setUpBoard; |
jens@10 | 32 |
|
jens@22 | 33 |
/** Called after the tablePerspectiveAngle property changes. */ |
jens@22 | 34 |
- (void) perspectiveChanged; |
jens@22 | 35 |
|
jens@10 | 36 |
/** Should return the winning player, if the current position is a win, else nil. |
jens@10 | 37 |
Default implementation returns nil. */ |
jens@10 | 38 |
- (Player*) checkForWinner; |
jens@10 | 39 |
|
jens@10 | 40 |
|
jens@10 | 41 |
#pragma mark Protected methods for subclasses to call: |
jens@10 | 42 |
|
jens@10 | 43 |
/** Sets the number of players in the game. Subclass initializers should call this. */ |
jens@10 | 44 |
- (void) setNumberOfPlayers: (unsigned)n; |
jens@10 | 45 |
|
jens@22 | 46 |
/** The angle by which the table is tilted "away from" the viewer to give 3D perspective. |
jens@22 | 47 |
Subclasses should not change this! It won't do anything. */ |
jens@22 | 48 |
@property CGFloat tablePerspectiveAngle; |
jens@22 | 49 |
|
jens@10 | 50 |
/** Animate a piece moving from src to dst. Used in implementing -applyMoveString:. */ |
jens@10 | 51 |
- (BOOL) animateMoveFrom: (CALayer<BitHolder>*)src to: (CALayer<BitHolder>*)dst; |
jens@10 | 52 |
|
jens@10 | 53 |
/** Animate a piece being placed in dst. Used in implementing -applyMoveString:. */ |
jens@10 | 54 |
- (BOOL) animatePlacementIn: (CALayer<BitHolder>*)dst; |
jens@10 | 55 |
|
jens@10 | 56 |
/** Checks for a winner and advances to the next player. */ |
jens@10 | 57 |
- (void) endTurn; |
jens@10 | 58 |
|
jens@10 | 59 |
@end |
jens@10 | 60 |
|
jens@10 | 61 |
|
jens@10 | 62 |
/** Optional Game API for tracking the history of a game, and being able to replay moves. */ |
jens@10 | 63 |
@interface Game (State) |
jens@10 | 64 |
|
jens@10 | 65 |
/** A string describing the current state of the game (the positions of all pieces, |
jens@10 | 66 |
orderings of cards, player scores, ... */ |
jens@10 | 67 |
@property (copy) NSString* stateString; |
jens@10 | 68 |
|
jens@10 | 69 |
/** Add a move to the game based on the contents of the string. |
jens@10 | 70 |
The string must have been returned by -currentMove at some point. */ |
jens@10 | 71 |
- (BOOL) applyMoveString: (NSString*)move; |
jens@10 | 72 |
|
jens@12 | 73 |
/** An optional method called as a subroutine by -[Grid setStateString:]. |
jens@12 | 74 |
If you decide to call that in your -setStateString: implementation, you need to implement this too. */ |
jens@12 | 75 |
- (Piece*) makePieceNamed: (NSString*)name; |
jens@12 | 76 |
|
jens@10 | 77 |
@end |