Graph::Easy::Layout::Path

TriggerTek Logo
abcdefghijklmnopqrstuvwxyz_
Graph::Easy::Layout::User(Contributed Perl DocumeGraph::Easy::Layout::Path(3)



NAME
       Graph::Easy::Layout::Path - Path management for Manhattan-style grids

SYNOPSIS
	       use Graph::Easy;

	       my $graph = Graph::Easy->new();

	       my $bonn = Graph::Easy::Node->new(
		       name => ’Bonn’,
	       );
	       my $berlin = Graph::Easy::Node->new(
		       name => ’Berlin’,
	       );

	       $graph->add_edge ($bonn, $berlin);

	       $graph->layout();

	       print $graph->as_ascii( );

	       # prints:

	       # +------+     +--------+
	       # │ Bonn │ --> │ Berlin │
	       # +------+     +--------+

DESCRIPTION
       "Graph::Easy::Layout::Scout" contains just the actual path-managing
       code for Graph::Easy, e.g. to create/destroy/maintain paths, node
       placement etc.

EXPORT
       Exports nothing.

SEE ALSO
       Graph::Easy.

METHODS into Graph::Easy
       This module injects the following methods into "Graph::Easy":

       _path_is_clear()

	       $graph->_path_is_clear($path);

       For all points (x,y pairs) in the path, check that the cell is still
       free.  $path points to a list x,y,type pairs as in "[ [x,y,type],
       [x,y,type], ...]".

       _create_cell()

	       my $cell = $graph->($edge,$x,$y,$type);

       Create a cell at "$x,$y" coordinates with type $type for the specified
       edge.

       _path_is_clear()

	       $graph->_path_is_clear();

       For all points (x,y pairs) in the path, check that the cell is still
       free.  $path points to a list of "[ x,y,type, x,y,type, ...]".

       Returns true when the path is clear, false otherwise.

       _trace_path()

	       my $path = my $graph->_trace_path($src,$dst,$edge);

       Find a free way from source node/group to destination node/group for
       the specified edge. Both source and destination need to be placed
       beforehand.

METHODS in Graph::Easy::Node
       This module injects the following methods into "Graph::Easy::Node":

       _near_places()

	       my $node->_near_places();

       Take a node and return a list of possible placements around it and
       prune out already occupied cells. $d is the distance from the node
       border and defaults to two (for placements). Set it to one for adja-
       cent cells.

       _shuffle_dir()

	       my $dirs = $node->_shuffle_dir( [ 0,1,2,3 ], $dir);

       Take a ref to an array with four entries and shuffle them around
       according to $dir.

       _shift()

	       my $dir = $node->_shift($degrees);

       Return a the "flow()" direction shifted by X degrees to $dir.

AUTHOR
       Copyright (C) 2004 - 2007 by Tels <http://bloodgate.com>.

       See the LICENSE file for information.



perl v5.8.8			  2008-04-19	 Graph::Easy::Layout::Path(3)