1 | <?php |
||
6 | class Astar |
||
7 | { |
||
8 | |||
9 | private $diagonal = false; |
||
10 | private $blocked = array(); |
||
11 | /** |
||
12 | * @var HeuristicInterface |
||
13 | */ |
||
14 | private $heuristic = null; |
||
15 | private $grid = null; |
||
16 | |||
17 | |||
18 | 1 | public function blocked(array $types) |
|
22 | |||
23 | 1 | public function enableDiagonal() |
|
24 | { |
||
25 | 1 | $this->diagonal = true; |
|
26 | 1 | } |
|
27 | |||
28 | 5 | public function __construct(Grid $grid) |
|
32 | |||
33 | 5 | public function setHeuristic(HeuristicInterface $heuristic) |
|
37 | |||
38 | 5 | public function search(Node $start, Node $end) |
|
55 | |||
56 | /** |
||
57 | * @param Node $end |
||
58 | * @param $heap |
||
59 | * @param $current |
||
60 | * @return Node |
||
61 | */ |
||
62 | 5 | private function fillHeap(\SplHeap $heap, Node $current, Node $end) |
|
93 | |||
94 | /** |
||
95 | * @param Node $current |
||
96 | * @return array |
||
97 | */ |
||
98 | 4 | private function getReversedPath(Node $current) |
|
107 | } |