34#ifndef FGGROUNDCALLBACK_H
35#define FGGROUNDCALLBACK_H
96 {
return GetAGLevel(time, location, contact, normal, v, w); }
108 virtual void SetEllipse(
double semimajor,
double semiminor) {}
129 a(semiMajor), b(semiMinor) {}
131 double GetAGLevel(
double t,
const FGLocation& location,
137 { mTerrainElevation = h; }
140 { a = semimajor; b = semiminor; }
144 double mTerrainElevation = 0.0;
This class implements a 3 element column vector.
void SetTerrainElevation(double h) override
Set the terrain elevation.
void SetEllipse(double semimajor, double semiminor) override
Set the planet semimajor and semiminor axes.
This class provides callback slots to get ground specific data.
virtual double GetAGLevel(double t, const FGLocation &location, FGLocation &contact, FGColumnVector3 &normal, FGColumnVector3 &v, FGColumnVector3 &w) const =0
Compute the altitude above ground.
virtual void SetEllipse(double semimajor, double semiminor)
Set the planet semimajor and semiminor axes.
virtual void SetTerrainElevation(double h)
Set the terrain elevation.
virtual double GetAGLevel(const FGLocation &location, FGLocation &contact, FGColumnVector3 &normal, FGColumnVector3 &v, FGColumnVector3 &w) const
Compute the altitude above ground.
void SetTime(double _time)
Set the simulation time.
FGLocation holds an arbitrary location in the Earth centered Earth fixed reference frame (ECEF).