mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-07 00:18:29 -04:00
AC_Fence: convert degrees to meters correctly
This commit is contained in:
parent
2ca827f66c
commit
1bca12ab26
@ -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;
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user