A bot used for https://code-your-snake.codingmaster398.repl.co/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.7 KiB
53 lines
1.7 KiB
3 years ago
|
# Diagonal Movement
|
||
|
To disable diagonal movement you need to configure the finder. The finder takes
|
||
|
a configuration object with an option called `diagonalMovement`. Setting this
|
||
|
option to `DiagonalMovement.Never` will disable diagonal movement completely.
|
||
|
Let us try it.
|
||
|
|
||
|
```javascript
|
||
|
var finder = new PF.AStarFinder({
|
||
|
diagonalMovement: PF.DiagonalMovement.Never
|
||
|
});
|
||
|
```
|
||
|
|
||
|
See that the path is straight now:
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/68d16/68d16efa5d105da2e5a741e69182db9e8d2ccd03" alt="Screenshot"
|
||
|
|
||
|
The `diagonalMovement` option can take any of the following values:
|
||
|
|
||
|
* Always
|
||
|
* Never
|
||
|
* IfAtMostOneObstacle
|
||
|
* OnlyWhenNoObstacles
|
||
|
|
||
|
To understand them consider the following four simple maps labelled A, B, C and
|
||
|
D. A has no obstacles for diagonal movement from green to orange cell, B and C
|
||
|
have one obstacle and D has two obstacles.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/29ded/29deda933a58bfaa62a3b686cc4b625280f502ba" alt="Screenshot"
|
||
|
|
||
|
## Always
|
||
|
With this option PathFinding.js will always find a diagonal path, irrespective
|
||
|
of the obstacles when moving diagonally.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/1cc13/1cc13a81ba4e64c8c3619389eeda1bf184d3efca" alt="Screenshot"
|
||
|
|
||
|
## Never
|
||
|
With this option PathFinding.js will only find straight paths and will never
|
||
|
find any diagonal paths.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/b19b2/b19b2234d7c67701790e7b1d5ac76b6ff6756224" alt="Screenshot"
|
||
|
|
||
|
## IfAtMostOneObstacle
|
||
|
With this option PathFinding.js will find diagonal paths only if there is at
|
||
|
most one obstacle for the diagonal path.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/c2035/c20355694cb65341402dabb48e7f88973957d11d" alt="Screenshot"
|
||
|
|
||
|
## OnlyWhenNoObstacles
|
||
|
With this option PathFinding.js will find diagonal paths only if there are no
|
||
|
obstacles for the diagonal path.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/a5fa2/a5fa2ad05db300ab5ea6939d3551bce9c778940f" alt="Screenshot"
|