Describes a single node for the LayeredGridGraph.
Works almost the same as a grid node, except that it also stores to which layer the connections go to
|
| LevelGridNode (AstarPath astar) |
|
override void | AddConnection (GraphNode node, uint cost) |
|
override void | ClearConnections (bool alsoReverse) |
| Remove all connections from this node.
|
|
override void | DeserializeNode (GraphSerializationContext ctx) |
|
override void | FloodFill (Stack< GraphNode > stack, uint region) |
|
bool | GetConnection (int i) |
| Is there a grid connection in that direction.
|
|
override void | GetConnections (GraphNodeDelegate del) |
| Calls the delegate with all connections from this node.
|
|
int | GetConnectionValue (int dir) |
| Which layer a grid connection goes to.
|
|
override bool | GetPortal (GraphNode other, List< Vector3 > left, List< Vector3 > right, bool backwards) |
| Add a portal from this node to the specified node.
|
|
bool | HasAnyGridConnections () |
| Does this node have any grid connections.
|
|
override void | Open (Path path, PathNode pathNode, PathHandler handler) |
| Open the node.
|
|
override void | RemoveConnection (GraphNode node) |
|
void | ResetAllGridConnections () |
| Removes all grid connections from this node.
|
|
override void | SerializeNode (GraphSerializationContext ctx) |
|
void | SetConnectionValue (int dir, int value) |
| Set which layer a grid connection goes to.
|
|
void | SetPosition (Int3 position) |
|
override void | UpdateRecursiveG (Path path, PathNode pathNode, PathHandler handler) |
|
override bool GetPortal |
( |
GraphNode |
other, |
|
|
List< Vector3 > |
left, |
|
|
List< Vector3 > |
right, |
|
|
bool |
backwards |
|
) |
| |
|
virtual |
Add a portal from this node to the specified node.
This function should add a portal to the left and right lists which is connecting the two nodes (this and other).
- Parameters
-
other | The node which is on the other side of the portal (strictly speaking it does not actually have to be on the other side of the portal though). |
left | List of portal points on the left side of the funnel |
right | List of portal points on the right side of the funnel |
backwards | If this is true, the call was made on a node with the other node as the node before this one in the path. In this case you may choose to do nothing since a similar call will be made to the other node with this node referenced as other (but then with backwards = true). You do not have to care about switching the left and right lists, that is done for you already. |
- Returns
- True if the call was deemed successful. False if some unknown case was encountered and no portal could be added. If both calls to node1.GetPortal (node2,...) and node2.GetPortal (node1,...) return false, the funnel modifier will fall back to adding to the path the positions of the node.
The default implementation simply returns false.
This function may add more than one portal if necessary.
- See Also
- http://digestingduck.blogspot.se/2010/03/simple-stupid-funnel-algorithm.html
Reimplemented from GraphNode.