diff --git a/libraries/AP_Common/Location.cpp b/libraries/AP_Common/Location.cpp index b3ac1e535a..a13a251a5f 100644 --- a/libraries/AP_Common/Location.cpp +++ b/libraries/AP_Common/Location.cpp @@ -461,3 +461,13 @@ int32_t Location::limit_lattitude(int32_t lat) } return lat; } + +// update altitude and alt-frame base on this location's horizontal position between point1 and point2 +// this location's lat,lon is used to calculate the alt of the closest point on the line between point1 and point2 +// origin and destination's altitude frames must be the same +// this alt-frame will be updated to match the destination alt frame +void Location::linearly_interpolate_alt(const Location &point1, const Location &point2) +{ + // new target's distance along the original track and then linear interpolate between the original origin and destination altitudes + set_alt_cm(point1.alt + (point2.alt - point1.alt) * constrain_float(line_path_proportion(point1, point2), 0.0f, 1.0f), point2.get_alt_frame()); +} diff --git a/libraries/AP_Common/Location.h b/libraries/AP_Common/Location.h index 78fbb256a4..8f5a34c3ac 100644 --- a/libraries/AP_Common/Location.h +++ b/libraries/AP_Common/Location.h @@ -118,6 +118,12 @@ public: */ float line_path_proportion(const Location &point1, const Location &point2) const; + // update altitude and alt-frame base on this location's horizontal position between point1 and point2 + // this location's lat,lon is used to calculate the alt of the closest point on the line between point1 and point2 + // origin and destination's altitude frames must be the same + // this alt-frame will be updated to match the destination alt frame + void linearly_interpolate_alt(const Location &point1, const Location &point2); + bool initialised() const { return (lat !=0 || lng != 0 || alt != 0); } // wrap longitude at -180e7 to 180e7