Add CTemperatureLayer, CTemperatureLayerList and CWindLayerList classes

refs #556
This commit is contained in:
Roland Winklmeier
2016-01-13 20:41:09 +01:00
parent c47d56b984
commit 59508305ae
9 changed files with 341 additions and 0 deletions

View File

@@ -0,0 +1,90 @@
/* 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_WEATHER_TEMPERATURELAYER_H
#define BLACKMISC_WEATHER_TEMPERATURELAYER_H
#include "blackmisc/blackmiscexport.h"
#include "blackmisc/valueobject.h"
#include "blackmisc/propertyindex.h"
#include "blackmisc/blackmiscfreefunctions.h"
#include "blackmisc/aviation/altitude.h"
#include "blackmisc/pq/temperature.h"
namespace BlackMisc
{
namespace Weather
{
/*!
* Value object for a temperature layer
*/
class BLACKMISC_EXPORT CTemperatureLayer : public CValueObject<CTemperatureLayer>
{
public:
//! Properties by index
enum ColumnIndex
{
IndexTemperatureLayer = BlackMisc::CPropertyIndex::GlobalIndexCTemperatureLayer,
IndexLevel,
IndexTemperature,
IndexRelativeHumidity
};
//! Default constructor.
CTemperatureLayer() = default;
//! Constructor
CTemperatureLayer(const BlackMisc::Aviation::CAltitude &level, const PhysicalQuantities::CTemperature &value, double relativeHumidity);
//! Set level
void setLevel(const BlackMisc::Aviation::CAltitude &level) { m_level = level; }
//! Get level
BlackMisc::Aviation::CAltitude getLevel() const { return m_level; }
//! Set temperature
void setTemperature(const PhysicalQuantities::CTemperature &value) { m_temperature = value; }
//! Get temperature
PhysicalQuantities::CTemperature getTemperature() const { return m_temperature; }
//! Set relative humidity
void setRelativeHumidity(double value) { m_relativeHumidity = value; }
//! Get relative humidity
double getRelativeHumidity() const { return m_relativeHumidity; }
//! \copydoc CValueObject::propertyByIndex
CVariant propertyByIndex(const BlackMisc::CPropertyIndex &index) const;
//! \copydoc CValueObject::setPropertyByIndex
void setPropertyByIndex(const CVariant &variant, const BlackMisc::CPropertyIndex &index);
//! \copydoc CValueObject::convertToQString
QString convertToQString(bool i18n = false) const;
private:
BLACK_ENABLE_TUPLE_CONVERSION(CTemperatureLayer)
BlackMisc::Aviation::CAltitude m_level;
PhysicalQuantities::CTemperature m_temperature;
double m_relativeHumidity = 0;
};
} // namespace
} // namespace
Q_DECLARE_METATYPE(BlackMisc::Weather::CTemperatureLayer)
BLACK_DECLARE_TUPLE_CONVERSION(BlackMisc::Weather::CTemperatureLayer, (
attr(o.m_level),
attr(o.m_temperature),
attr(o.m_relativeHumidity)
))
#endif // guard