AC_Fence: convert degrees to meters correctly

This commit is contained in:
Andy Piper 2024-12-19 21:06:52 +00:00
parent 2ca827f66c
commit 1bca12ab26
2 changed files with 5 additions and 6 deletions

View File

@ -669,13 +669,10 @@ bool AC_Fence::check_fence_polygon()
const bool was_breached = _breached_fences & AC_FENCE_TYPE_POLYGON; const bool was_breached = _breached_fences & AC_FENCE_TYPE_POLYGON;
Location loc; Location loc;
if (!AP::ahrs().get_location(loc)) { bool have_location = AP::ahrs().get_location(loc);
return false;
}
bool inside_margin = false; bool inside_margin = false;
if (_poly_loader.breached(loc, _margin, inside_margin)) { if (have_location && _poly_loader.breached(loc, _margin, inside_margin)) {
if (!was_breached) { if (!was_breached) {
record_breach(AC_FENCE_TYPE_POLYGON); record_breach(AC_FENCE_TYPE_POLYGON);
return true; return true;

View File

@ -234,16 +234,18 @@ bool AC_PolyFence_loader::breached(const Location& loc, float margin, bool& insi
Vector2l pos; Vector2l pos;
pos.x = loc.lat; pos.x = loc.lat;
pos.y = loc.lng; pos.y = loc.lng;
margin = margin * 1.0e7 / 11132.0; // convert margin to degrees margin = margin * 1.0e7 / 111132.954; // convert margin to degrees
const uint16_t num_inclusion = _num_loaded_circle_inclusion_boundaries + _num_loaded_inclusion_boundaries; const uint16_t num_inclusion = _num_loaded_circle_inclusion_boundaries + _num_loaded_inclusion_boundaries;
uint16_t num_inclusion_outside = 0; uint16_t num_inclusion_outside = 0;
inside_margin = false; inside_margin = false;
// check we are inside each inclusion zone: // check we are inside each inclusion zone:
for (uint8_t i=0; i<_num_loaded_inclusion_boundaries; i++) { for (uint8_t i=0; i<_num_loaded_inclusion_boundaries; i++) {
const InclusionBoundary &boundary = _loaded_inclusion_boundary[i]; const InclusionBoundary &boundary = _loaded_inclusion_boundary[i];
if (Polygon_outside(pos, boundary.points_lla, boundary.count)) { if (Polygon_outside(pos, boundary.points_lla, boundary.count)) {
GCS_SEND_TEXT(MAV_SEVERITY_INFO, "%f %f", Polygon_closest_distance_point(boundary.points_lla, boundary.count, pos), margin);
num_inclusion_outside++; num_inclusion_outside++;
} else if (Polygon_closest_distance_point(boundary.points_lla, boundary.count, pos) < margin) { } else if (Polygon_closest_distance_point(boundary.points_lla, boundary.count, pos) < margin) {
inside_margin = true; inside_margin = true;