A* Pathfinding Project
4.1.4
The A* Pathfinding Project for Unity 3D
|
Finds all nodes within a specified distance from the start. More...
Finds all nodes within a specified distance from the start.
This class will search outwards from the start point and find all nodes which it costs less than ConstantPath.maxGScore to reach, this is usually the same as the distance to them multiplied with 1000
The path can be called like:
Then when getting the callback, all nodes will be stored in the variable ConstantPath.allNodes (remember that you need to cast it from Path to ConstantPath first to get the variable).
This list will be sorted by the cost to reach that node (more specifically the G score if you are familiar with the terminology for search algorithms).
Static Public Member Functions | |
static ConstantPath | Construct (Vector3 start, int maxGScore, OnPathDelegate callback=null) |
Constructs a ConstantPath starting from the specified point. | |
Public Attributes | |
List< GraphNode > | allNodes |
Contains all nodes the path found. | |
PathEndingCondition | endingCondition |
Controls when the path should terminate. | |
Vector3 | originalStartPoint |
GraphNode | startNode |
Vector3 | startPoint |
Public Attributes inherited from Path | |
OnPathDelegate | callback |
Callback to call when the path is complete. | |
int | enabledTags = -1 |
Which graph tags are traversable. | |
Heuristic | heuristic |
Determines which heuristic to use. | |
float | heuristicScale = 1F |
Scale of the heuristic values. | |
OnPathDelegate | immediateCallback |
Immediate callback to call when the path is complete. | |
NNConstraint | nnConstraint = PathNNConstraint.Default |
Constraint for how to search for nodes. | |
List< GraphNode > | path |
Holds the path as a Node array. | |
ITraversalProvider | traversalProvider |
Provides additional traversal information to a path request. | |
List< Vector3 > | vectorPath |
Holds the (possibly post processed) path as a Vector3 list. | |
Protected Member Functions | |
override void | CalculateStep (long targetTick) |
Calculates the until it is complete or the time has progressed past targetTick. | |
override void | Cleanup () |
Always called after the path has been calculated. | |
override void | Initialize () |
Initializes the path. | |
override void | OnEnterPool () |
Called when the path enters the pool. | |
override void | Prepare () |
Called before the path is started. | |
override void | Reset () |
Reset the path to default values. | |
void | Setup (Vector3 start, int maxGScore, OnPathDelegate callback) |
Sets up a ConstantPath starting from the specified point. | |
Protected Member Functions inherited from Path | |
void | DebugStringPrefix (PathLog logMode, System.Text.StringBuilder text) |
Writes text shared for all overrides of DebugString to the string builder. | |
void | DebugStringSuffix (PathLog logMode, System.Text.StringBuilder text) |
Writes text shared for all overrides of DebugString to the string builder. | |
void | PrepareBase (PathHandler pathHandler) |
Prepares low level path variables for calculation. | |
virtual void | ReturnPath () |
Calls callback to return the calculated path. | |
virtual void | Trace (PathNode from) |
Traces the calculated path from the end node to the start. | |
Properties | |
override bool | FloodingPath [get] |
Properties inherited from Path | |
PathCompleteState | CompleteState [get, set] |
Current state of the path. | |
bool | error [get] |
If the path failed, this is true. | |
string | errorLog [get, set] |
Additional info on why a path failed. | |
virtual bool | FloodingPath [get] |
True for paths that want to search all nodes and not jump over nodes as optimizations. | |
PathHandler IPathInternals. | PathHandler [get] |
ushort | pathID [get, set] |
ID of this path. | |
PathState | PipelineState [get, set] |
Returns the state of the path in the pathfinding pipeline. | |
bool IPathInternals. | Pooled [get, set] |
True if the path is currently pooled. | |
bool | recycled [get] |
True if the path is currently recycled (i.e in the path pool). | |
int[] | tagPenalties [get, set] |
Penalties for each tag. | |
Properties inherited from IPathInternals | |
PathHandler | PathHandler [get] |
bool | Pooled [get, set] |
Additional Inherited Members | |
Public Member Functions inherited from Path | |
void | BlockUntilCalculated () |
Blocks until this path has been calculated and returned. | |
void | Claim (System.Object o) |
Claim this path (pooling). | |
void | Error () |
Aborts the path because of an error. | |
PathState | GetState () |
Returns the state of the path in the pathfinding pipeline. | |
float | GetTotalLength () |
Total Length of the path. | |
bool | IsDone () |
Returns if this path is done calculating. | |
void | Release (System.Object o, bool silent=false) |
Releases a path claim (pooling). | |
IEnumerator | WaitForPath () |
Waits until this path has been calculated and returned. | |
Protected Attributes inherited from Path | |
PathNode | currentR |
The node currently being processed. | |
bool | hasBeenReset |
True if the Reset function has been called. | |
Int3 | hTarget |
Target to use for H score calculations. | |
GraphNode | hTargetNode |
Target to use for H score calculation. | |
int[] | internalTagPenalties |
The tag penalties that are actually used. | |
int[] | manualTagPenalties |
Tag penalties set by other scripts. | |
PathHandler | pathHandler |
Data for the thread calculating this path. | |
Package Functions inherited from Path | |
uint | CalculateHScore (GraphNode node) |
Estimated cost from the specified node to the target. | |
bool | CanTraverse (GraphNode node) |
Returns if the node can be traversed. | |
virtual string | DebugString (PathLog logMode) |
Returns a string with information about it. | |
void | FailWithError (string msg) |
Causes the path to fail and sets errorLog to msg. | |
virtual uint | GetConnectionSpecialCost (GraphNode a, GraphNode b, uint currentCost) |
May be called by graph nodes to get a special cost for some connections. | |
Int3 | GetHTarget () |
uint | GetTagPenalty (int tag) |
Returns penalty for the given tag. | |
uint | GetTraversalCost (GraphNode node) |
void | Log (string msg) |
Appends a message to the errorLog. | |
void | LogError (string msg) |
Logs an error. | |
void | ReleaseSilent (System.Object o) |
Releases the path silently (pooling). | |
Package Attributes inherited from Path | |
float | duration |
How long it took to calculate this path in milliseconds. | |
Path | next |
Internal linked list implementation. | |
int | searchedNodes |
Number of nodes this path has searched. | |
|
protectedvirtual |
Calculates the until it is complete or the time has progressed past targetTick.
Implements Path.
|
protectedvirtual |
Always called after the path has been calculated.
Guaranteed to be called before other paths have been calculated on the same thread. Use for cleaning up things like node tagging and similar.
Reimplemented from Path.
|
static |
Constructs a ConstantPath starting from the specified point.
start | From where the path will be started from (the closest node to that point will be used) |
maxGScore | Searching will be stopped when a node has a G score greater than this |
callback | Will be called when the path has completed, leave this to null if you use a Seeker to handle calls |
Searching will be stopped when a node has a G score (cost to reach it) greater or equal to maxGScore in order words it will search all nodes with a cost to get there less than maxGScore.
|
protectedvirtual |
|
protectedvirtual |
Called when the path enters the pool.
This method should release e.g pooled lists and other pooled resources The base version of this method releases vectorPath and path lists. Reset() will be called after this function, not before.
Reimplemented from Path.
|
protectedvirtual |
|
protectedvirtual |
Reset the path to default values.
Clears the allNodes list.
Also sets heuristic to Heuristic.None as it is the default value for this path type
Reimplemented from Path.
|
protected |
Sets up a ConstantPath starting from the specified point.
List<GraphNode> allNodes |
Contains all nodes the path found.
This list will be sorted by G score (cost/distance to reach the node).
PathEndingCondition endingCondition |
Controls when the path should terminate.
This is set up automatically in the constructor to an instance of the Pathfinding.EndingConditionDistance class with a maxGScore is specified in the constructor. If you want to use another ending condition.
Vector3 originalStartPoint |
GraphNode startNode |
Vector3 startPoint |
|
getpackage |