Class AbstractPathfinder
java.lang.Object
de.bsommerfeld.pathetic.engine.pathfinder.AbstractPathfinder
- All Implemented Interfaces:
Pathfinder
- Direct Known Subclasses:
AStarPathfinder
Provides a skeletal implementation of the
Pathfinder interface, defining common behavior
for pathfinding algorithms.
This pathfinder operates by iteratively processing nodes from an open set (priority queue) until the target is reached or other termination conditions are met. It supports asynchronous execution and customizable hooks for observing the pathfinding steps. The "tick-wise" nature mentioned previously refers to each main loop iteration processing one node.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected static final Set<PathPosition>protected final NavigationPointProviderprotected final List<NodeCostProcessor>protected final List<NodeValidationProcessor>protected final Iterable<PathVector>protected final PathfinderConfiguration -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedAbstractPathfinder(PathfinderConfiguration pathfinderConfiguration) -
Method Summary
Modifier and TypeMethodDescriptionvoidabort()Requests the current pathfinding operation to abort.protected NodecreateStartNode(PathPosition startPos, PathPosition targetPos) Creates the initialNodefor the start position.findPath(PathPosition start, PathPosition target, EnvironmentContext environmentContext) Tries to find a path between the specified start and target positions within the provided environment context.protected abstract voidPrepares the algorithm-specific initial setup required before executing the pathfinding logic.protected abstract voidmarkNodeAsExpanded(Node node) Marks the given node as expanded (i.e., added to the "closed set").protected abstract voidAbstract method for algorithm-specific cleanup, called after pathfinding execution.protected abstract voidprocessSuccessors(PathPosition requestStart, PathPosition requestTarget, Node currentNode, org.jheaps.tree.FibonacciHeap<Double, Node> openSet, SearchContext searchContext) Abstract method representing the core logic of processing successor nodes for a givencurrentNode.protected PathreconstructPath(Node endNode) Reconstructs the path by tracing back from the given end node to the start node.voidRegisters aPathfinderHookthat will be called on every step of the pathfinding process.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface de.bsommerfeld.pathetic.api.pathing.Pathfinder
findPath
-
Field Details
-
EMPTY_PATH_POSITIONS
-
pathfinderConfiguration
-
nodeValidationProcessors
-
nodeCostProcessors
-
offsets
-
-
Constructor Details
-
AbstractPathfinder
-
-
Method Details
-
findPath
public CompletionStage<PathfinderResult> findPath(PathPosition start, PathPosition target, EnvironmentContext environmentContext) Description copied from interface:PathfinderTries to find a path between the specified start and target positions within the provided environment context.- Specified by:
findPathin interfacePathfinder- Parameters:
start- The starting position for pathfinding.target- The target position for pathfinding.environmentContext- The environment context that provides additional information for the pathfinding operation. This parameter can be null if no specific context is required.- Returns:
- A
CompletionStagecontaining thePathfinderResultof the pathfinding operation, indicating the outcome and the resulting path.
-
abort
public void abort()Requests the current pathfinding operation to abort. The abortion is cooperative and might not be immediate.- Specified by:
abortin interfacePathfinder- See Also:
-
registerPathfindingHook
Description copied from interface:PathfinderRegisters aPathfinderHookthat will be called on every step of the pathfinding process. This can be used to modify the pathfinding process or to collect data.- Specified by:
registerPathfindingHookin interfacePathfinder- Parameters:
hook- The hook to register.
-
createStartNode
Creates the initialNodefor the start position.- Parameters:
startPos- The effective start position.targetPos- The effective target position.- Returns:
- The created start node.
-
reconstructPath
Reconstructs the path by tracing back from the given end node to the start node.- Parameters:
endNode- The node from which to trace back.- Returns:
- The reconstructed
Path.
-
initializeSearch
protected abstract void initializeSearch()Prepares the algorithm-specific initial setup required before executing the pathfinding logic. This method is designed to be overridden by subclasses to implement their respective initialization logic, such as setting up data structures, precomputing values, or resetting internal state. It is called at the beginning of a pathfinding request. -
markNodeAsExpanded
Marks the given node as expanded (i.e., added to the "closed set"). Subclasses should implement this to update their specific closed set mechanism.- Parameters:
node- The node that has been taken from the open set and is being expanded.
-
performAlgorithmCleanup
protected abstract void performAlgorithmCleanup()Abstract method for algorithm-specific cleanup, called after pathfinding execution. To be implemented by subclasses likeAStarPathfinder. -
processSuccessors
protected abstract void processSuccessors(PathPosition requestStart, PathPosition requestTarget, Node currentNode, org.jheaps.tree.FibonacciHeap<Double, Node> openSet, SearchContext searchContext) Abstract method representing the core logic of processing successor nodes for a givencurrentNode. Implementations (like A*) should:- Generate potential successor positions.
- Create
Nodeobjects for these successors. - Validate these nodes (e.g., traversability, bounds, visited status). This is where processors will hook in.
- Calculate their G and H costs. G-costs will be influenced by cost processors.
- Add valid successor nodes with their F-costs to the
openSet.
- Parameters:
requestStart- The original startPathPositionof the pathfinding request.requestTarget- The original targetPathPositionof the pathfinding request.currentNode- The currentNodebeing expanded.openSet- The priority queue (open set) to add new successor nodes to.
-