mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 22:48:29 -04:00
023f56aa70
This commit changes the way libraries headers are included in source files: - If the header is in the same directory the source belongs to, so the notation '#include ""' is used with the path relative to the directory containing the source. - If the header is outside the directory containing the source, then we use the notation '#include <>' with the path relative to libraries folder. Some of the advantages of such approach: - Only one search path for libraries headers. - OSs like Windows may have a better lookup time.
62 lines
1.9 KiB
C++
62 lines
1.9 KiB
C++
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
/// @file limits.h
|
|
/// @brief Imposes limits on location (geofence), altitude and other parameters.
|
|
/// Each limit breach will trigger an action or set of actions to recover. Adapted from geofence.
|
|
/// @author Andrew Tridgell
|
|
/// Andreas Antonopoulos
|
|
|
|
#ifndef __AP_LIMIT_GEOFENCE_H__
|
|
#define __AP_LIMIT_GEOFENCE_H__
|
|
|
|
#include "AP_Limits.h"
|
|
#include "AP_Limit_Module.h"
|
|
#include <AP_Math/AP_Math.h>
|
|
#include <AP_Param/AP_Param.h>
|
|
#include <GPS.h>
|
|
#include <StorageManager/StorageManager.h>
|
|
|
|
#define MAX_FENCEPOINTS 6
|
|
|
|
class AP_Limit_Geofence : public AP_Limit_Module {
|
|
|
|
public:
|
|
AP_Limit_Geofence(uint16_t eeprom_fence_start, uint8_t fpsize, uint8_t max_fp, GPS *&gps, const struct Location *home_loc, const struct Location *current_loc);
|
|
bool init();
|
|
bool triggered();
|
|
|
|
AP_Int8 fence_total();
|
|
void set_fence_point_with_index(Vector2l &point, uint8_t i);
|
|
Vector2l get_fence_point_with_index(uint8_t i);
|
|
void update_boundary();
|
|
bool boundary_correct();
|
|
|
|
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
protected:
|
|
|
|
// pointers to gps, current location and home
|
|
GPS *& _gps;
|
|
const struct Location * _current_loc;
|
|
const struct Location * _home;
|
|
|
|
|
|
// Simple mode, just radius
|
|
AP_Int8 _simple; // 1 = simple, 0 = complex
|
|
AP_Int16 _radius; // in meters, for simple mode
|
|
|
|
// Complex mode, defined fence points
|
|
AP_Int8 _fence_total;
|
|
AP_Int8 _num_points;
|
|
|
|
private:
|
|
static StorageAccess _storage;
|
|
bool _boundary_uptodate;
|
|
Vector2l _boundary[MAX_FENCEPOINTS]; // complex mode fence
|
|
|
|
};
|
|
|
|
#endif // __AP_LIMIT_GEOFENCE_H__
|