summaryrefslogtreecommitdiffstats
path: root/core/math/a_star.cpp
diff options
context:
space:
mode:
authorDmDerbin <dds9435@gmail.com>2017-11-02 22:42:58 +0300
committerDmDerbin <dds9435@gmail.com>2017-11-04 11:21:03 +0300
commit4c79e58e3fcb4fe1aa81bc5085a8b0f7e7f92673 (patch)
treeb0990bb7004036ab78e8fcc612dca20e2667c19f /core/math/a_star.cpp
parentc880302754352dce1e44bf00bf9b1ac20e71cd1d (diff)
downloadredot-engine-4c79e58e3fcb4fe1aa81bc5085a8b0f7e7f92673.tar.gz
AStar: implementation of get_point_connections
Diffstat (limited to 'core/math/a_star.cpp')
-rw-r--r--core/math/a_star.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/core/math/a_star.cpp b/core/math/a_star.cpp
index f43af49754..7e26761abf 100644
--- a/core/math/a_star.cpp
+++ b/core/math/a_star.cpp
@@ -159,6 +159,21 @@ Array AStar::get_points() {
return point_list;
}
+PoolVector<int> AStar::get_point_connections(int p_id) {
+
+ ERR_FAIL_COND_V(!points.has(p_id), PoolVector<int>());
+
+ PoolVector<int> point_list;
+
+ Point *p = points[p_id];
+
+ for (int i = 0; i < p->neighbours.size(); i++) {
+ point_list.push_back(p->neighbours[i]->id);
+ }
+
+ return point_list;
+}
+
bool AStar::are_points_connected(int p_id, int p_with_id) const {
Segment s(p_id, p_with_id);
@@ -444,6 +459,8 @@ void AStar::_bind_methods() {
ClassDB::bind_method(D_METHOD("has_point", "id"), &AStar::has_point);
ClassDB::bind_method(D_METHOD("get_points"), &AStar::get_points);
+ ClassDB::bind_method(D_METHOD("get_point_connections"), &AStar::get_point_connections);
+
ClassDB::bind_method(D_METHOD("connect_points", "id", "to_id", "bidirectional"), &AStar::connect_points, DEFVAL(true));
ClassDB::bind_method(D_METHOD("disconnect_points", "id", "to_id"), &AStar::disconnect_points);
ClassDB::bind_method(D_METHOD("are_points_connected", "id", "to_id"), &AStar::are_points_connected);