Source/Grid.h
author Jens Alfke <jens@mooseyard.com>
Tue Mar 11 09:21:53 2008 -0700 (2008-03-11)
changeset 3 40d225cf9c43
parent 0 e9f7ba4718e1
child 7 428a194e3e59
permissions -rw-r--r--
Added support for clicking the board to place new pieces. Go and Tic-Tac-Toe now use this.
     1 /*  This code is based on Apple's "GeekGameBoard" sample code, version 1.0.
     2     http://developer.apple.com/samplecode/GeekGameBoard/
     3     Copyright © 2007 Apple Inc. Copyright © 2008 Jens Alfke. All Rights Reserved.
     4 
     5     Redistribution and use in source and binary forms, with or without modification, are permitted
     6     provided that the following conditions are met:
     7 
     8     * Redistributions of source code must retain the above copyright notice, this list of conditions
     9       and the following disclaimer.
    10     * Redistributions in binary form must reproduce the above copyright notice, this list of
    11       conditions and the following disclaimer in the documentation and/or other materials provided
    12       with the distribution.
    13 
    14     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
    15     IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND 
    16     FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRI-
    17     BUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
    18     (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
    19     PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
    20     CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 
    21     THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
    22 */
    23 #import "BitHolder.h"
    24 @class GridCell;
    25 
    26 
    27 /** Abstract superclass of regular geometric grids of GridCells that Bits can be placed on. */
    28 @interface Grid : GGBLayer
    29 {
    30     unsigned _nRows, _nColumns;                         
    31     CGSize _spacing;                                    
    32     Class _cellClass;                                   
    33     CGColorRef _cellColor, _lineColor;                  
    34     BOOL _usesDiagonals, _allowsMoves, _allowsCaptures;
    35     NSMutableArray *_cells;                             // Really a 2D array, in row-major order.
    36 }
    37 
    38 /** Initializes a new Grid with the given dimensions and cell size, and position in superview.
    39     Note that a new Grid has no cells! Either call -addAllCells, or -addCellAtRow:column:. */
    40 - (id) initWithRows: (unsigned)nRows columns: (unsigned)nColumns
    41             spacing: (CGSize)spacing
    42            position: (CGPoint)pos;
    43 
    44 /** Initializes a new Grid with the given dimensions and frame in superview.
    45     The cell size will be computed by dividing frame size by dimensions.
    46     Note that a new Grid has no cells! Either call -addAllCells, or -addCellAtRow:column:. */
    47 - (id) initWithRows: (unsigned)nRows columns: (unsigned)nColumns
    48               frame: (CGRect)frame;
    49 
    50 @property Class cellClass;                      // What kind of GridCells to create
    51 @property (readonly) unsigned rows, columns;    // Dimensions of the grid
    52 @property (readonly) CGSize spacing;            // x,y spacing of GridCells
    53 @property CGColorRef cellColor, lineColor;      // Cell background color, line color (or nil)
    54 @property BOOL usesDiagonals;                   // Affects GridCell.neighbors, for rect grids
    55 @property BOOL allowsMoves, allowsCaptures;     // Can pieces be moved, and can they land on others?
    56 
    57 /** Returns the GridCell at the given coordinates, or nil if there is no cell there.
    58     It's OK to call this with off-the-board coordinates; it will just return nil.*/
    59 - (GridCell*) cellAtRow: (unsigned)row column: (unsigned)col;
    60 
    61 /** Adds cells at all coordinates, creating a complete grid. */
    62 - (void) addAllCells;
    63 
    64 /** Adds a GridCell at the given coordinates. */
    65 - (GridCell*) addCellAtRow: (unsigned)row column: (unsigned)col;
    66 
    67 /** Removes a particular cell, leaving a blank space. */
    68 - (void) removeCellAtRow: (unsigned)row column: (unsigned)col;
    69 
    70 
    71 // protected:
    72 - (GridCell*) createCellAtRow: (unsigned)row column: (unsigned)col 
    73                suggestedFrame: (CGRect)frame;
    74 
    75 @end
    76 
    77 
    78 /** Abstract superclass of a single cell in a grid. */
    79 @interface GridCell : BitHolder
    80 {
    81     Grid *_grid;
    82     unsigned _row, _column;
    83 }
    84 
    85 - (id) initWithGrid: (Grid*)grid 
    86                 row: (unsigned)row column: (unsigned)col
    87               frame: (CGRect)frame;
    88 
    89 @property (readonly) Grid* grid;
    90 @property (readonly) unsigned row, column;
    91 @property (readonly) NSArray* neighbors;        // Dependent on grid.usesDiagonals
    92 
    93 /** Returns YES if 'forward' is north (increasing row#) for the current player */
    94 @property (readonly) BOOL fwdIsN;
    95 
    96 /* Go-style group detection. Returns the set of contiguous GridCells that have pieces of the same
    97    owner as this one, and optionally a count of the number of "liberties", or adjacent empty cells. */
    98 - (NSSet*) getGroup: (int*)outLiberties;
    99 
   100 // protected:
   101 - (void) drawInParentContext: (CGContextRef)ctx fill: (BOOL)fill;
   102 @end
   103 
   104 
   105 
   106 /** A rectangular grid of squares. */
   107 @interface RectGrid : Grid
   108 {
   109     CGColorRef _altCellColor;
   110 }
   111 
   112 /** If non-nil, alternate cells will be drawn with this background color, in a checkerboard pattern.
   113     The precise rule is that cells whose row+column is odd use the altCellColor.*/
   114 @property CGColorRef altCellColor;
   115 
   116 @end
   117 
   118 
   119 
   120 /* A square in a RectGrid */
   121 @interface Square : GridCell
   122 
   123 @property (readonly) Square *nw, *n, *ne, *e, *se, *s, *sw, *w;    // Absolute directions (n = increasing row#)
   124 @property (readonly) Square *fl, *f, *fr, *r, *br, *b, *bl, *l;    // Relative to player (upside-down for player 2)
   125 
   126 @end
   127 
   128 
   129 /* Substitute this for Square in a RectGrid's cellClass to draw the lines through the centers
   130    of the squares, so the pieces sit on the intersections, as in a Go board. */
   131 @interface GoSquare : Square
   132 {
   133     BOOL _dotted;
   134 }
   135 
   136 /** Set to YES to put a dot at the intersection, as in the handicap points of a Go board. */
   137 @property BOOL dotted;
   138 
   139 @end