-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSingleStepPathingStrategy.java
30 lines (29 loc) · 1.03 KB
/
SingleStepPathingStrategy.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import java.util.function.Predicate;
import java.util.function.BiPredicate;
import java.util.function.Function;
import java.util.stream.Stream;
import java.util.stream.Collectors;
import java.util.List;
class SingleStepPathingStrategy
implements PathingStrategy
{
public List<Point> computePath(Point start, Point end,
Predicate<Point> canPassThrough,
BiPredicate<Point, Point> withinReach,
Function<Point, Stream<Point>> potentialNeighbors)
{
/* Does not check withinReach. Since only a single step is taken
* on each call, the caller will need to check if the destination
* has been reached.
*/
return potentialNeighbors.apply(start)
.filter(canPassThrough)
.filter(pt ->
!pt.equals(start)
&& !pt.equals(end)
&& Math.abs(end.getX() - pt.getX()) <= Math.abs(end.getX() - start.getX())
&& Math.abs(end.getY() - pt.getY()) <= Math.abs(end.getY() - start.getY()))
.limit(1)
.collect(Collectors.toList());
}
}