mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-02 06:35:52 +08:00
refs #201, support for flight level in altitude (needed for flight plan)
This commit is contained in:
@@ -4,6 +4,7 @@
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#include "avaltitude.h"
|
||||
#include "pqstring.h"
|
||||
|
||||
using BlackMisc::PhysicalQuantities::CLength;
|
||||
using BlackMisc::PhysicalQuantities::CLengthUnit;
|
||||
@@ -13,13 +14,29 @@ namespace BlackMisc
|
||||
namespace Aviation
|
||||
{
|
||||
|
||||
/*
|
||||
* Constructor
|
||||
*/
|
||||
CAltitude::CAltitude(const QString &altitudeAsString) : BlackMisc::PhysicalQuantities::CLength(0, BlackMisc::PhysicalQuantities::CLengthUnit::m()), m_datum(MeanSeaLevel)
|
||||
{
|
||||
this->parseFromString(altitudeAsString);
|
||||
}
|
||||
|
||||
/*
|
||||
* Own implementation for streaming
|
||||
*/
|
||||
QString CAltitude::convertToQString(bool /* i18n */) const
|
||||
{
|
||||
QString s = this->CLength::convertToQString();
|
||||
return s.append(this->isMeanSeaLevel() ? " MSL" : " AGL");
|
||||
if (this->m_datum == FlightLevel)
|
||||
{
|
||||
int fl = qRound(this->CLength::value(CLengthUnit::ft()) / 100.0);
|
||||
return QString("FL%1").arg(fl);
|
||||
}
|
||||
else
|
||||
{
|
||||
QString s = this->CLength::convertToQString();
|
||||
return s.append(this->isMeanSeaLevel() ? " MSL" : " AGL");
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -58,6 +75,24 @@ namespace BlackMisc
|
||||
return !((*this) == other);
|
||||
}
|
||||
|
||||
/*
|
||||
* To FL
|
||||
*/
|
||||
void CAltitude::toFLightLevel()
|
||||
{
|
||||
Q_ASSERT(this->m_datum == MeanSeaLevel || this->m_datum == FlightLevel);
|
||||
this->m_datum = FlightLevel;
|
||||
}
|
||||
|
||||
/*
|
||||
* To MSL
|
||||
*/
|
||||
void CAltitude::toMeanSeaLevel()
|
||||
{
|
||||
Q_ASSERT(this->m_datum == MeanSeaLevel || this->m_datum == FlightLevel);
|
||||
this->m_datum = MeanSeaLevel;
|
||||
}
|
||||
|
||||
/*
|
||||
* metaTypeId
|
||||
*/
|
||||
@@ -117,6 +152,44 @@ namespace BlackMisc
|
||||
BlackMisc::deserializeJson(json, CAltitude::jsonMembers(), TupleConverter<CAltitude>::toTuple(*this));
|
||||
}
|
||||
|
||||
/*
|
||||
* Parse value
|
||||
*/
|
||||
void CAltitude::parseFromString(const QString &value)
|
||||
{
|
||||
QString v = value.trimmed();
|
||||
|
||||
// special case FL
|
||||
if (v.contains("FL", Qt::CaseInsensitive))
|
||||
{
|
||||
v = v.replace("FL", "", Qt::CaseInsensitive).trimmed();
|
||||
this->m_datum = FlightLevel;
|
||||
bool ok = false;
|
||||
double dv = v.toDouble(&ok) * 100.0;
|
||||
CLength l(ok ? dv : 0.0,
|
||||
ok ? CLengthUnit::ft() : CLengthUnit::nullUnit());
|
||||
this->set(l);
|
||||
return;
|
||||
}
|
||||
|
||||
// normal altitude, AGL/MSL
|
||||
if (v.contains("MSL", Qt::CaseInsensitive))
|
||||
{
|
||||
v = v.replace("MSL", "", Qt::CaseInsensitive).trimmed();
|
||||
this->m_datum = MeanSeaLevel;
|
||||
}
|
||||
else if (v.contains("AGL"))
|
||||
{
|
||||
v = v.replace("AGL", "", Qt::CaseInsensitive).trimmed();
|
||||
this->m_datum = AboveGround;
|
||||
}
|
||||
else
|
||||
this->m_datum = MeanSeaLevel;
|
||||
|
||||
CLength l = BlackMisc::PhysicalQuantities::CPqString::parse<CLength>(v);
|
||||
this->set(l);
|
||||
}
|
||||
|
||||
/*
|
||||
* Members
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user