mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 18:18:49 -04:00
APM: use AHRS position for geo-fence
this allows it to take account of dead-reckoning
This commit is contained in:
parent
3f76a4cc61
commit
c652538516
@ -121,8 +121,9 @@ failed:
|
|||||||
static bool geofence_enabled(void)
|
static bool geofence_enabled(void)
|
||||||
{
|
{
|
||||||
if (g.fence_action == FENCE_ACTION_NONE ||
|
if (g.fence_action == FENCE_ACTION_NONE ||
|
||||||
g.fence_channel == 0 ||
|
(g.fence_action != FENCE_ACTION_REPORT &&
|
||||||
APM_RC.InputCh(g.fence_channel-1) < FENCE_ENABLE_PWM) {
|
(g.fence_channel == 0 ||
|
||||||
|
APM_RC.InputCh(g.fence_channel-1) < FENCE_ENABLE_PWM))) {
|
||||||
// geo-fencing is disabled
|
// geo-fencing is disabled
|
||||||
if (geofence_state != NULL) {
|
if (geofence_state != NULL) {
|
||||||
// re-arm for when the channel trigger is switched on
|
// re-arm for when the channel trigger is switched on
|
||||||
@ -131,11 +132,6 @@ static bool geofence_enabled(void)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!g_gps->fix) {
|
|
||||||
// we can't do much without a GPS fix
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,6 +199,7 @@ static void geofence_check(bool altitude_check_only)
|
|||||||
|
|
||||||
bool outside = false;
|
bool outside = false;
|
||||||
uint8_t breach_type = FENCE_BREACH_NONE;
|
uint8_t breach_type = FENCE_BREACH_NONE;
|
||||||
|
struct Location loc;
|
||||||
|
|
||||||
if (geofence_check_minalt()) {
|
if (geofence_check_minalt()) {
|
||||||
outside = true;
|
outside = true;
|
||||||
@ -210,10 +207,10 @@ static void geofence_check(bool altitude_check_only)
|
|||||||
} else if (geofence_check_maxalt()) {
|
} else if (geofence_check_maxalt()) {
|
||||||
outside = true;
|
outside = true;
|
||||||
breach_type = FENCE_BREACH_MAXALT;
|
breach_type = FENCE_BREACH_MAXALT;
|
||||||
} else if (!altitude_check_only) {
|
} else if (!altitude_check_only && ahrs.get_position(&loc)) {
|
||||||
Vector2l location;
|
Vector2l location;
|
||||||
location.x = current_loc.lat;
|
location.x = loc.lat;
|
||||||
location.y = current_loc.lng;
|
location.y = loc.lng;
|
||||||
outside = Polygon_outside(location, &geofence_state->boundary[1], geofence_state->num_points-1);
|
outside = Polygon_outside(location, &geofence_state->boundary[1], geofence_state->num_points-1);
|
||||||
if (outside) {
|
if (outside) {
|
||||||
breach_type = FENCE_BREACH_BOUNDARY;
|
breach_type = FENCE_BREACH_BOUNDARY;
|
||||||
|
Loading…
Reference in New Issue
Block a user