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/73278/732785a344e2cc78b512c61a668fea6ee8800a94" 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/7acf9/7acf936b5da149a6593d3382aa502ebced9f9a82" 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/d1b74/d1b7438350c918df81bc83d5accb58e34d82b12a" 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/b9b2d/b9b2d874876377df9c97f837410fa37764f21aa9" 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/e3a0a/e3a0a6ba229be8f38781a57fddf6ea25ab4c89df" 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/ded80/ded800ff217091aeac00e05936b4eb92bcbb3268" alt="Screenshot"
|