mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-27 11:05:44 +08:00
* Include only what is used * Use forward declaration when possible * Sorted includes refs #630
187 lines
8.1 KiB
C++
187 lines
8.1 KiB
C++
/* Copyright (C) 2013
|
|
* swift project Community / Contributors
|
|
*
|
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
|
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
|
|
* including this file, may be copied, modified, propagated, or distributed except according to the terms
|
|
* contained in the LICENSE file.
|
|
*/
|
|
|
|
//! \file
|
|
|
|
#ifndef BLACKMISC_AVIATION_AIRCRAFTSITUATION_H
|
|
#define BLACKMISC_AVIATION_AIRCRAFTSITUATION_H
|
|
|
|
#include "blackmisc/aviation/altitude.h"
|
|
#include "blackmisc/aviation/callsign.h"
|
|
#include "blackmisc/aviation/heading.h"
|
|
#include "blackmisc/blackmiscexport.h"
|
|
#include "blackmisc/geo/coordinategeodetic.h"
|
|
#include "blackmisc/geo/latitude.h"
|
|
#include "blackmisc/geo/longitude.h"
|
|
#include "blackmisc/metaclass.h"
|
|
#include "blackmisc/pq/angle.h"
|
|
#include "blackmisc/pq/length.h"
|
|
#include "blackmisc/pq/speed.h"
|
|
#include "blackmisc/propertyindex.h"
|
|
#include "blackmisc/timestampbased.h"
|
|
#include "blackmisc/valueobject.h"
|
|
#include "blackmisc/variant.h"
|
|
|
|
#include <QMetaType>
|
|
#include <QString>
|
|
#include <QVector3D>
|
|
#include <array>
|
|
|
|
namespace BlackMisc
|
|
{
|
|
namespace Aviation
|
|
{
|
|
//! Value object encapsulating information of an aircraft's situation
|
|
class BLACKMISC_EXPORT CAircraftSituation :
|
|
public CValueObject<CAircraftSituation>,
|
|
public BlackMisc::Geo::ICoordinateGeodetic, public BlackMisc::ITimestampBased
|
|
{
|
|
public:
|
|
//! Properties by index
|
|
enum ColumnIndex
|
|
{
|
|
IndexPosition = BlackMisc::CPropertyIndex::GlobalIndexCAircraftSituation,
|
|
IndexLatitude,
|
|
IndexLongitude,
|
|
IndexAltitude,
|
|
IndexHeading,
|
|
IndexBank,
|
|
IndexPitch,
|
|
IndexGroundspeed,
|
|
IndexCallsign
|
|
};
|
|
|
|
//! Default constructor.
|
|
CAircraftSituation() {}
|
|
|
|
//! Comprehensive constructor
|
|
CAircraftSituation(const BlackMisc::Geo::CCoordinateGeodetic &position, const BlackMisc::Aviation::CAltitude &altitude,
|
|
const BlackMisc::Aviation::CHeading &heading = {},
|
|
const BlackMisc::PhysicalQuantities::CAngle &pitch = {},
|
|
const BlackMisc::PhysicalQuantities::CAngle &bank = {},
|
|
const BlackMisc::PhysicalQuantities::CSpeed &gs = {});
|
|
|
|
//! Comprehensive constructor
|
|
CAircraftSituation(const BlackMisc::Aviation::CCallsign &correspondingCallsign,
|
|
const BlackMisc::Geo::CCoordinateGeodetic &position, const BlackMisc::Aviation::CAltitude &altitude,
|
|
const BlackMisc::Aviation::CHeading &heading = {},
|
|
const BlackMisc::PhysicalQuantities::CAngle &pitch = {},
|
|
const BlackMisc::PhysicalQuantities::CAngle &bank = {},
|
|
const BlackMisc::PhysicalQuantities::CSpeed &gs = {});
|
|
|
|
//! \copydoc BlackMisc::Mixin::Index::propertyByIndex
|
|
CVariant propertyByIndex(const BlackMisc::CPropertyIndex &index) const;
|
|
|
|
//! \copydoc BlackMisc::Mixin::Index::setPropertyByIndex
|
|
void setPropertyByIndex(const BlackMisc::CPropertyIndex &index, const CVariant &variant);
|
|
|
|
//! Get position
|
|
const BlackMisc::Geo::CCoordinateGeodetic &getPosition() const { return this->m_position; }
|
|
|
|
//! Set position
|
|
void setPosition(const BlackMisc::Geo::CCoordinateGeodetic &position) { this->m_position = position; }
|
|
|
|
//! \copydoc Geo::ICoordinateGeodetic::latitude()
|
|
virtual BlackMisc::Geo::CLatitude latitude() const override { return this->m_position.latitude(); }
|
|
|
|
//! \copydoc Geo::ICoordinateGeodetic::longitude()
|
|
virtual BlackMisc::Geo::CLongitude longitude() const override { return this->m_position.longitude(); }
|
|
|
|
//! Guess if aircraft is "on ground"
|
|
virtual bool isOnGroundGuessed() const;
|
|
|
|
//! \copydoc Geo::ICoordinateGeodetic::geodeticHeight
|
|
//! \remarks this should be used for elevation as depicted here: http://en.wikipedia.org/wiki/Altitude#mediaviewer/File:Vertical_distances.svg
|
|
const BlackMisc::PhysicalQuantities::CLength &geodeticHeight() const override { return this->m_position.geodeticHeight(); }
|
|
|
|
//! \copydoc Geo::ICoordinateGeodetic::normalVector
|
|
virtual QVector3D normalVector() const override { return this->m_position.normalVector(); }
|
|
|
|
//! \copydoc Geo::ICoordinateGeodetic::normalVectorDouble
|
|
virtual std::array<double, 3> normalVectorDouble() const override { return this->m_position.normalVectorDouble(); }
|
|
|
|
//! Elevation
|
|
//! \sa geodeticHeight
|
|
const BlackMisc::PhysicalQuantities::CLength getElevation() const { return this->geodeticHeight(); }
|
|
|
|
//! Elevation
|
|
//! \sa setGeodeticHeight
|
|
void setElevation(const BlackMisc::PhysicalQuantities::CLength &elevation) { return this->m_position.setGeodeticHeight(elevation); }
|
|
|
|
//! Height above ground.
|
|
//! Do not confuse with elevation (=geodeticHeight) as in \sa geodeticHeight() / \sa getElevation()
|
|
BlackMisc::PhysicalQuantities::CLength getHeightAboveGround() const;
|
|
|
|
//! Get heading
|
|
const BlackMisc::Aviation::CHeading &getHeading() const { return this->m_heading; }
|
|
|
|
//! Set heading
|
|
void setHeading(const BlackMisc::Aviation::CHeading &heading) { this->m_heading = heading; }
|
|
|
|
//! Get altitude (true)
|
|
const BlackMisc::Aviation::CAltitude &getAltitude() const { return this->m_altitude; }
|
|
|
|
//! Set altitude
|
|
void setAltitude(const BlackMisc::Aviation::CAltitude &altitude) { this->m_altitude = altitude; }
|
|
|
|
//! Get pitch
|
|
const BlackMisc::PhysicalQuantities::CAngle &getPitch() const { return this->m_pitch; }
|
|
|
|
//! Set pitch
|
|
void setPitch(const BlackMisc::PhysicalQuantities::CAngle &pitch) { this->m_pitch = pitch; }
|
|
|
|
//! Get bank (angle)
|
|
const BlackMisc::PhysicalQuantities::CAngle &getBank() const { return this->m_bank; }
|
|
|
|
//! Set bank (angle)
|
|
void setBank(const BlackMisc::PhysicalQuantities::CAngle &bank) { this->m_bank = bank; }
|
|
|
|
//! Get ground speed
|
|
const BlackMisc::PhysicalQuantities::CSpeed &getGroundSpeed() const { return this->m_groundSpeed; }
|
|
|
|
//! Set ground speed
|
|
void setGroundSpeed(const BlackMisc::PhysicalQuantities::CSpeed &groundspeed) { this->m_groundSpeed = groundspeed; }
|
|
|
|
//! Corresponding callsign
|
|
const BlackMisc::Aviation::CCallsign &getCallsign() const { return this->m_correspondingCallsign; }
|
|
|
|
//! Corresponding callsign
|
|
void setCallsign(const BlackMisc::Aviation::CCallsign &callsign);
|
|
|
|
//! \copydoc BlackMisc::Mixin::String::toQString
|
|
QString convertToQString(bool i18n = false) const;
|
|
|
|
private:
|
|
CCallsign m_correspondingCallsign;
|
|
BlackMisc::Geo::CCoordinateGeodetic m_position;
|
|
BlackMisc::Aviation::CAltitude m_altitude;
|
|
BlackMisc::Aviation::CHeading m_heading;
|
|
BlackMisc::PhysicalQuantities::CAngle m_pitch;
|
|
BlackMisc::PhysicalQuantities::CAngle m_bank;
|
|
BlackMisc::PhysicalQuantities::CSpeed m_groundSpeed;
|
|
|
|
BLACK_METACLASS(
|
|
CAircraftSituation,
|
|
BLACK_METAMEMBER(correspondingCallsign),
|
|
BLACK_METAMEMBER(position),
|
|
BLACK_METAMEMBER(altitude),
|
|
BLACK_METAMEMBER(heading),
|
|
BLACK_METAMEMBER(pitch),
|
|
BLACK_METAMEMBER(bank),
|
|
BLACK_METAMEMBER(groundSpeed),
|
|
BLACK_METAMEMBER(timestampMSecsSinceEpoch)
|
|
);
|
|
};
|
|
} // namespace
|
|
} // namespace
|
|
|
|
Q_DECLARE_METATYPE(BlackMisc::Aviation::CAircraftSituation)
|
|
|
|
#endif // guard
|