diff options
| author | Kirill Petrashin <kirill8201@yandex.ru> | 2026-04-23 14:29:15 +0300 |
|---|---|---|
| committer | Kirill Petrashin <kirill8201@yandex.ru> | 2026-04-23 14:29:15 +0300 |
| commit | 6834ffa31842ca249514854bac8bae0f0022f104 (patch) | |
| tree | e3b2c68ee6951727b65910b5bfe7876646c756bd | |
| parent | fbde58b3509184a687759bc822b5567e9a13d2bc (diff) | |
| download | astar-6834ffa31842ca249514854bac8bae0f0022f104.tar.xz | |
Make wraparound toggleable with a keybind
| -rw-r--r-- | main.c | 17 | ||||
| -rw-r--r-- | map.c | 2 | ||||
| -rw-r--r-- | path.c | 10 | ||||
| -rw-r--r-- | path.h | 3 |
4 files changed, 28 insertions, 4 deletions
@@ -186,6 +186,8 @@ int main(int argc, char **argv) { * * [d] - Switch algorithms (A* or Dijsktra's) * + * [f] - Toggle wraparound + * * [r] - Reverse the path and switch start/end around * * [s] - Save the map to a bmp file @@ -271,13 +273,26 @@ int main(int argc, char **argv) { break; case 'd': - if (path_func == astar_path) { set_message("Dijkstra"); path_func = &dijkstra_path; } + if (path_func == astar_path) { set_message("Dijkstra's"); path_func = &dijkstra_path; } else { set_message("A*"); path_func = &astar_path; }; path_free(path, height); path = path_func(dirs, map, cell_costs, width, height, start_pos, end_pos, visited, anim); /* TODO: print time */ break; + case 'f': + wraparound_enabled = !wraparound_enabled; + if (wraparound_enabled) + set_message("Enabled wraparound, only works on Dijkstra's") + else + set_message("Disabled wraparound"); + + if (path_func == dijkstra_path) { + path_free(path, height); + path = path_func(dirs, map, cell_costs, width, height, start_pos, end_pos, visited, anim); + } + break; + case 'r': path_reverse(&path, width, height, &start_pos, &end_pos); break; @@ -715,7 +715,7 @@ void map_editor(Map *map, size_t *width, size_t *height, Position *start, Positi break; case 'd': - if (path_func == astar_path) { set_message("Dijkstra"); path_func = &dijkstra_path; } + if (path_func == astar_path) { set_message("Dijkstra's"); path_func = &dijkstra_path; } else { set_message("A*"); path_func = &astar_path; }; path_free(path, *height); if (should_pathfind) path = path_func(dirs, *map, NULL, *width, *height, *start, *goal, visited, 0); @@ -16,6 +16,8 @@ Path (*path_func)(int, Map, size_t **, size_t, size_t, Position, Position, char **, char) = &astar_path; double path_time = 0; +char wraparound_enabled = 0; + char anim_automatic = 0; /* TODO: make it move the map maybe to show the path */ @@ -134,8 +136,12 @@ Path dijkstra_path(int dirs, Map map, size_t **cell_costs, size_t width, size_t unsigned int (*neighbours)(Position[], size_t[], Position, size_t, size_t, char**, size_t**) = NULL; switch (dirs) { - case 4: neighbours = &neighbours_4dir; break; - case 8: neighbours = &neighbours_8dir; break; + case 4: if (wraparound_enabled) neighbours = &neighbours_4dir_wraparound; + else neighbours = &neighbours_4dir; + break; + case 8: if (wraparound_enabled) neighbours = &neighbours_8dir_wraparound; + else neighbours = &neighbours_8dir; + break; default: error("Tried to call dijkstra_path with wrong direction amount\n"); } @@ -9,6 +9,9 @@ extern Path (*path_func)(int, Map, size_t **, size_t, size_t, Position, Position /* Time it took to calculate a path */ extern double path_time; +/* Controls whether walls should wrap around, only works in Dijkstra's */ +extern char wraparound_enabled; + /* dirs can be 4 or 8 to disallow or allow diagonal movement */ //Path breadth_first_search_path(int dirs, Map map, size_t **cell_costs, size_t width, size_t height, Position start, Position end, char **visited, char should_anim); Path dijkstra_path(int dirs, Map map, size_t **cell_costs, size_t width, size_t height, Position start, Position end, char **visited, char should_anim); |
