2015-12-30 18:57:56 -04:00
|
|
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
|
|
|
//
|
|
|
|
// functions to support precision landing
|
|
|
|
//
|
|
|
|
|
2016-01-14 15:30:56 -04:00
|
|
|
#include "Sub.h"
|
2015-12-30 18:57:56 -04:00
|
|
|
|
|
|
|
#if PRECISION_LANDING == ENABLED
|
|
|
|
|
2016-07-23 02:50:24 -03:00
|
|
|
void Sub::init_precland()
|
2015-12-30 18:57:56 -04:00
|
|
|
{
|
2016-07-23 02:50:24 -03:00
|
|
|
sub.precland.init();
|
2015-12-30 18:57:56 -04:00
|
|
|
}
|
|
|
|
|
2016-07-23 02:50:24 -03:00
|
|
|
void Sub::update_precland()
|
2015-12-30 18:57:56 -04:00
|
|
|
{
|
2016-07-23 02:50:24 -03:00
|
|
|
int32_t height_above_ground_cm = current_loc.alt;
|
2015-12-30 18:57:56 -04:00
|
|
|
|
2016-07-23 02:50:24 -03:00
|
|
|
// use range finder altitude if it is valid, else try to get terrain alt
|
|
|
|
if (rangefinder_alt_ok()) {
|
|
|
|
height_above_ground_cm = rangefinder_state.alt_cm;
|
|
|
|
} else if (terrain_use()) {
|
|
|
|
current_loc.get_alt_cm(Location_Class::ALT_FRAME_ABOVE_TERRAIN, height_above_ground_cm);
|
2015-12-30 18:57:56 -04:00
|
|
|
}
|
|
|
|
|
2016-07-23 02:50:24 -03:00
|
|
|
sub.precland.update(height_above_ground_cm);
|
2015-12-30 18:57:56 -04:00
|
|
|
|
|
|
|
// log output
|
|
|
|
Log_Write_Precland();
|
|
|
|
}
|
|
|
|
#endif
|