|
@@ -354,10 +354,13 @@ void NavigationPolygon::_bind_methods() {
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "outlines", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NO_EDITOR | PROPERTY_USAGE_INTERNAL), "_set_outlines", "_get_outlines");
|
|
|
}
|
|
|
|
|
|
+/////////////////////////////
|
|
|
+
|
|
|
void NavigationRegion2D::set_enabled(bool p_enabled) {
|
|
|
if (enabled == p_enabled) {
|
|
|
return;
|
|
|
}
|
|
|
+
|
|
|
enabled = p_enabled;
|
|
|
|
|
|
if (!is_inside_tree()) {
|
|
@@ -384,35 +387,50 @@ bool NavigationRegion2D::is_enabled() const {
|
|
|
}
|
|
|
|
|
|
void NavigationRegion2D::set_navigation_layers(uint32_t p_navigation_layers) {
|
|
|
- NavigationServer2D::get_singleton()->region_set_navigation_layers(region, p_navigation_layers);
|
|
|
+ if (navigation_layers == p_navigation_layers) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ navigation_layers = p_navigation_layers;
|
|
|
+
|
|
|
+ NavigationServer2D::get_singleton()->region_set_navigation_layers(region, navigation_layers);
|
|
|
}
|
|
|
|
|
|
uint32_t NavigationRegion2D::get_navigation_layers() const {
|
|
|
- return NavigationServer2D::get_singleton()->region_get_navigation_layers(region);
|
|
|
+ return navigation_layers;
|
|
|
}
|
|
|
|
|
|
void NavigationRegion2D::set_navigation_layer_value(int p_layer_number, bool p_value) {
|
|
|
ERR_FAIL_COND_MSG(p_layer_number < 1, "Navigation layer number must be between 1 and 32 inclusive.");
|
|
|
ERR_FAIL_COND_MSG(p_layer_number > 32, "Navigation layer number must be between 1 and 32 inclusive.");
|
|
|
+
|
|
|
uint32_t _navigation_layers = get_navigation_layers();
|
|
|
+
|
|
|
if (p_value) {
|
|
|
_navigation_layers |= 1 << (p_layer_number - 1);
|
|
|
} else {
|
|
|
_navigation_layers &= ~(1 << (p_layer_number - 1));
|
|
|
}
|
|
|
+
|
|
|
set_navigation_layers(_navigation_layers);
|
|
|
}
|
|
|
|
|
|
bool NavigationRegion2D::get_navigation_layer_value(int p_layer_number) const {
|
|
|
ERR_FAIL_COND_V_MSG(p_layer_number < 1, false, "Navigation layer number must be between 1 and 32 inclusive.");
|
|
|
ERR_FAIL_COND_V_MSG(p_layer_number > 32, false, "Navigation layer number must be between 1 and 32 inclusive.");
|
|
|
+
|
|
|
return get_navigation_layers() & (1 << (p_layer_number - 1));
|
|
|
}
|
|
|
|
|
|
void NavigationRegion2D::set_enter_cost(real_t p_enter_cost) {
|
|
|
ERR_FAIL_COND_MSG(p_enter_cost < 0.0, "The enter_cost must be positive.");
|
|
|
- enter_cost = MAX(p_enter_cost, 0.0);
|
|
|
- NavigationServer2D::get_singleton()->region_set_enter_cost(region, p_enter_cost);
|
|
|
+ if (Math::is_equal_approx(enter_cost, p_enter_cost)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ enter_cost = p_enter_cost;
|
|
|
+
|
|
|
+ NavigationServer2D::get_singleton()->region_set_enter_cost(region, enter_cost);
|
|
|
}
|
|
|
|
|
|
real_t NavigationRegion2D::get_enter_cost() const {
|
|
@@ -421,7 +439,12 @@ real_t NavigationRegion2D::get_enter_cost() const {
|
|
|
|
|
|
void NavigationRegion2D::set_travel_cost(real_t p_travel_cost) {
|
|
|
ERR_FAIL_COND_MSG(p_travel_cost < 0.0, "The travel_cost must be positive.");
|
|
|
- travel_cost = MAX(p_travel_cost, 0.0);
|
|
|
+ if (Math::is_equal_approx(travel_cost, p_travel_cost)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ travel_cost = p_travel_cost;
|
|
|
+
|
|
|
NavigationServer2D::get_singleton()->region_set_travel_cost(region, travel_cost);
|
|
|
}
|
|
|
|
|
@@ -433,7 +456,6 @@ RID NavigationRegion2D::get_region_rid() const {
|
|
|
return region;
|
|
|
}
|
|
|
|
|
|
-/////////////////////////////
|
|
|
#ifdef TOOLS_ENABLED
|
|
|
Rect2 NavigationRegion2D::_edit_get_rect() const {
|
|
|
return navpoly.is_valid() ? navpoly->_edit_get_rect() : Rect2();
|