pathfinder

A simple pathfinding class for games; written in Crystal

Pathfinder

A simple pathfinding class for games; written in Crystal.

How to use

require "./pathfinder.cr"

# 0 = wall
# 1 = walkable
grid = [
  [1, 1, 1],
  [1, 0, 0],
  [1, 1, 1],
]

pf = Pathfinder.new(grid)

pf.start(0, 0)
pf.dest(2, 2)

result = pf.search

puts result # [{x: 0, y: 1}, {x: 0, y: 2}, {x: 1, y: 2}, {x: 2, y: 2}]

Accessing/modifying the grid

Pathfinder keeps a reference to the grid passed in. You can change the grid like this:

pf.grid[0][0] = 0 # set to wall.

Or by changing the grid that was passed in to the Pathfinder class at initializaton directly.

grid[0][0] = 1 # changes the pf.grid[0][0] to 1 too!
Owner
github statistic
  • 3
  • 0
  • 0
  • 0
  • almost 4 years ago
  • February 23, 2017
License

MIT License

Links
Synced at

Sat, 16 Jan 2021 14:46:20 GMT