mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-05-01 14:45:42 +08:00
refs #840, value classes for ground elevation plane
Can be used as single point elevation or plane covering an airport
This commit is contained in:
committed by
Mathew Sutcliffe
parent
ef04c05831
commit
70aee605cb
105
src/blackmisc/geo/elevationplane.cpp
Normal file
105
src/blackmisc/geo/elevationplane.cpp
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
/* Copyright (C) 2016
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "elevationplane.h"
|
||||||
|
#include "blackmisc/pq/length.h"
|
||||||
|
#include "blackmisc/propertyindex.h"
|
||||||
|
|
||||||
|
using namespace BlackMisc::PhysicalQuantities;
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
namespace Geo
|
||||||
|
{
|
||||||
|
QString CElevationPlane::convertToQString(bool i18n) const
|
||||||
|
{
|
||||||
|
QString s = "Geodetic: {%1, %2, %3} radius: %4";
|
||||||
|
return s.arg(this->latitude().valueRoundedWithUnit(6, i18n),
|
||||||
|
this->longitude().valueRoundedWithUnit(6, i18n),
|
||||||
|
this->geodeticHeight().valueRoundedWithUnit(6, i18n),
|
||||||
|
this->m_radius.valueRoundedWithUnit(2, i18n)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CElevationPlane::isNull() const
|
||||||
|
{
|
||||||
|
return m_radius.isNull();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CElevationPlane::isWithinRange(const ICoordinateGeodetic &coordinate) const
|
||||||
|
{
|
||||||
|
if (m_radius.isNull()) { return false; }
|
||||||
|
const CLength d = this->calculateGreatCircleDistance(coordinate);
|
||||||
|
const bool inRange = m_radius >= d;
|
||||||
|
return inRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CElevationPlane::setSinglePointRadius()
|
||||||
|
{
|
||||||
|
m_radius = singlePointRadius();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CElevationPlane::setMinorAirportRadius()
|
||||||
|
{
|
||||||
|
m_radius = minorAirportRadius();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CElevationPlane::setMajorAirportRadius()
|
||||||
|
{
|
||||||
|
m_radius = majorAirportRadius();
|
||||||
|
}
|
||||||
|
|
||||||
|
CVariant CElevationPlane::propertyByIndex(const BlackMisc::CPropertyIndex &index) const
|
||||||
|
{
|
||||||
|
if (index.isMyself()) { return CVariant::from(*this); }
|
||||||
|
const ColumnIndex i = index.frontCasted<ColumnIndex>();
|
||||||
|
switch (i)
|
||||||
|
{
|
||||||
|
case IndexRadius:
|
||||||
|
return m_radius.propertyByIndex(index.copyFrontRemoved());
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return CCoordinateGeodetic::propertyByIndex(index);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CElevationPlane::setPropertyByIndex(const CPropertyIndex &index, const CVariant &variant)
|
||||||
|
{
|
||||||
|
if (index.isMyself()) { (*this) = variant.to<CElevationPlane>(); return; }
|
||||||
|
const ColumnIndex i = index.frontCasted<ColumnIndex>();
|
||||||
|
switch (i)
|
||||||
|
{
|
||||||
|
case IndexRadius:
|
||||||
|
this->m_radius.setPropertyByIndex(index.copyFrontRemoved(), variant);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
CCoordinateGeodetic::setPropertyByIndex(index, variant);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const CLength &CElevationPlane::singlePointRadius()
|
||||||
|
{
|
||||||
|
static const CLength l(10.0, CLengthUnit::m());
|
||||||
|
return l;
|
||||||
|
}
|
||||||
|
|
||||||
|
const CLength &CElevationPlane::minorAirportRadius()
|
||||||
|
{
|
||||||
|
static const CLength l(500.0, CLengthUnit::m());
|
||||||
|
return l;
|
||||||
|
}
|
||||||
|
|
||||||
|
const CLength &CElevationPlane::majorAirportRadius()
|
||||||
|
{
|
||||||
|
static const CLength l(1000.0, CLengthUnit::m());
|
||||||
|
return l;
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
} // namespace
|
||||||
91
src/blackmisc/geo/elevationplane.h
Normal file
91
src/blackmisc/geo/elevationplane.h
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
/* Copyright (C) 2016
|
||||||
|
* 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_GEO_ELEVATIONPLANE_H
|
||||||
|
#define BLACKMISC_GEO_ELEVATIONPLANE_H
|
||||||
|
|
||||||
|
#include "blackmisc/blackmiscexport.h"
|
||||||
|
#include "blackmisc/geo/coordinategeodetic.h"
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
namespace Geo
|
||||||
|
{
|
||||||
|
//! Plane of same elevation, can be a single point or larger area (e.g. airport)
|
||||||
|
class BLACKMISC_EXPORT CElevationPlane :
|
||||||
|
public CValueObject<CElevationPlane, CCoordinateGeodetic>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
//! Properties by index
|
||||||
|
enum ColumnIndex
|
||||||
|
{
|
||||||
|
IndexRadius = BlackMisc::CPropertyIndex::GlobalIndexCElevationPlane
|
||||||
|
};
|
||||||
|
|
||||||
|
//! Default constructor
|
||||||
|
CElevationPlane() {}
|
||||||
|
|
||||||
|
//! Constructor
|
||||||
|
using CValueObject<CElevationPlane, CCoordinateGeodetic>::CValueObject;
|
||||||
|
|
||||||
|
//! Radius
|
||||||
|
const BlackMisc::PhysicalQuantities::CLength &getRadius() const { return m_radius; }
|
||||||
|
|
||||||
|
//! Radius
|
||||||
|
void setRadius(const BlackMisc::PhysicalQuantities::CLength &radius) { m_radius = radius; }
|
||||||
|
|
||||||
|
//! Existing value
|
||||||
|
bool isNull() const;
|
||||||
|
|
||||||
|
//! Check if elevation is within radius and can be used
|
||||||
|
bool isWithinRange(const BlackMisc::Geo::ICoordinateGeodetic &coordinate) const;
|
||||||
|
|
||||||
|
//! Treat as single point as obtained from simulator
|
||||||
|
void setSinglePointRadius();
|
||||||
|
|
||||||
|
//! Treat as elevation of a small airport
|
||||||
|
void setMinorAirportRadius();
|
||||||
|
|
||||||
|
//! Treat as elevation of a small airport
|
||||||
|
void setMajorAirportRadius();
|
||||||
|
|
||||||
|
//! \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);
|
||||||
|
|
||||||
|
//! \copydoc BlackMisc::Mixin::String::toQString
|
||||||
|
QString convertToQString(bool i18n = false) const;
|
||||||
|
|
||||||
|
//! Radius for single point
|
||||||
|
static const BlackMisc::PhysicalQuantities::CLength &singlePointRadius();
|
||||||
|
|
||||||
|
//! Radius for minor airport
|
||||||
|
static const BlackMisc::PhysicalQuantities::CLength &minorAirportRadius();
|
||||||
|
|
||||||
|
//! Radius for major airport
|
||||||
|
static const BlackMisc::PhysicalQuantities::CLength &majorAirportRadius();
|
||||||
|
|
||||||
|
private:
|
||||||
|
BlackMisc::PhysicalQuantities::CLength m_radius { 0, nullptr }; //!< elevation is valid in radius
|
||||||
|
|
||||||
|
BLACK_METACLASS(
|
||||||
|
CElevationPlane,
|
||||||
|
BLACK_METAMEMBER(radius)
|
||||||
|
);
|
||||||
|
};
|
||||||
|
} // namespace
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(BlackMisc::Geo::CElevationPlane)
|
||||||
|
|
||||||
|
#endif // guard
|
||||||
@@ -19,5 +19,6 @@
|
|||||||
#include "blackmisc/geo/latitude.h"
|
#include "blackmisc/geo/latitude.h"
|
||||||
#include "blackmisc/geo/longitude.h"
|
#include "blackmisc/geo/longitude.h"
|
||||||
#include "blackmisc/geo/coordinategeodetic.h"
|
#include "blackmisc/geo/coordinategeodetic.h"
|
||||||
|
#include "blackmisc/geo/elevationplane.h"
|
||||||
|
|
||||||
#endif // guard
|
#endif // guard
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ namespace BlackMisc
|
|||||||
CCoordinateGeodetic::registerMetadata();
|
CCoordinateGeodetic::registerMetadata();
|
||||||
CLatitude::registerMetadata();
|
CLatitude::registerMetadata();
|
||||||
CLongitude::registerMetadata();
|
CLongitude::registerMetadata();
|
||||||
|
CElevationPlane::registerMetadata();
|
||||||
}
|
}
|
||||||
} // ns
|
} // ns
|
||||||
} // ns
|
} // ns
|
||||||
|
|||||||
Reference in New Issue
Block a user