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 final List<CostProcessor>protected static final Set<PathPosition>protected final NavigationPointProviderprotected final INeighborStrategyprotected final PathfinderConfigurationprotected final List<ValidationProcessor> -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedAbstractPathfinder(PathfinderConfiguration pathfinderConfiguration) -
Method Summary
Modifier and TypeMethodDescriptionprotected NodecreateStartNode(PathPosition startPos, PathPosition targetPos) Creates the initialNodefor the start position.protected abstract NodeextractBestNode(MinHeap openSet) Extracts the node with the lowest cost from the open set and retrieves the corresponding Node object.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 voidinsertStartNode(Node node, double fCost, MinHeap openSet) Inserts the start node into the open set and updates any internal mapping.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, MinHeap openSet, SearchContext searchContext) Abstract method representing the core logic of processing successor nodes for a givencurrentNode.protected PathreconstructPath(PathPosition start, PathPosition target, 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
-
validationProcessors
-
costProcessors
-
neighborStrategy
-
-
Constructor Details
-
AbstractPathfinder
-
-
Method Details
-
findPath
public PathfindingSearch 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
PathfindingSearchinstance that can be used to configure and retrieve the result of the pathfinding operation.
-
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.
-
insertStartNode
Inserts the start node into the open set and updates any internal mapping. -
extractBestNode
Extracts the node with the lowest cost from the open set and retrieves the corresponding Node object. -
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, MinHeap 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.
-