NAME

Games::Battleship::Grid - A Battleship grid class

SYNOPSIS

use Games::Battleship::Grid;

$grid = Games::Battleship::Grid->new(
    fleet => \@fleet,
    dimension => [$width, $height],
);

ABSTRACT

A Battleship grid class

DESCRIPTION

A Games::Battleship::Grid object represents a Battleship grid class.

Note that the _segment_intersection method is really cool. : )

PUBLIC METHODS

new %ARGUMENTS
  • fleet => [$CRAFT_1, $CRAFT_2, ... $CRAFT_N]

    Array reference of an unlimited number of Games::Battleship::Craft objects.

    If provided, the fleet will be placed on the grid. It is required that the number of ships and their combined sizes be less than the area of the grid.

  • dimensions => [$WIDTH, $HEIGHT]

    Array reference with the grid height and width values.

PRIVATE METHODS AND FUNCTIONS

_init [$CRAFT_1, $CRAFT_2, ... $CRAFT_N]

Initialize the grid with the Games::Battleship::Craft object dimensions.

If an array reference of craft objects is provided, place them on the grid so that they do not intesect (overlap or touch).

_tail_coordinates @COORDINATES, $SPAN
($orientation, $x1, $y1) = _tail_coordinates($x0, $y0, $span);

Return the vertical or horizontal line segment orientation and the tail coordinates, based on the head coodinates and a span (the length of the segment).

Note that this routine is a function, not an object method.

_segment_intersection @COORDINATES
$intersect = _segment_intersection(
    px0, py0, px1, py1,
    qx0, qy0, qx1, qy1
);

Return zero if there is no intersection (or touching or overlap).

Each pair of values define a coordinate and each pair of coordinates define a line segment.

TO DO

Allow diagonal craft placement.

Allow some type of interactive craft repositioning.

Allow placement restriction rules (e.g. not on edges, not adjacent, etc.).

Allow > 2D playing spaces.

SEE ALSO

Games::Battleship

Games::Battleship::Craft

http://www.meca.ucl.ac.be/~wu/FSA2716/Exercise1.htm

AUTHOR

Gene Boggs <gene@cpan.org>

COPYRIGHT AND LICENSE

Copyright 2003, Gene Boggs

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.