Files
pilotclient/src/blackmisc/weather/temperaturelayer.cpp
Lars Toenning bcc4bdd31e Add SPDX identifiers for REUSE compliance
Co-authored-by: Mat Sutcliffe <oktal3700@gmail.com>
2023-10-03 09:29:49 +02:00

74 lines
2.5 KiB
C++

// SPDX-FileCopyrightText: Copyright (C) 2016 swift Project Community / Contributors
// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-swift-pilot-client-1
#include "blackmisc/weather/temperaturelayer.h"
#include "blackmisc/propertyindexref.h"
using namespace BlackMisc::Aviation;
using namespace BlackMisc::PhysicalQuantities;
BLACK_DEFINE_VALUEOBJECT_MIXINS(BlackMisc::Weather, CTemperatureLayer)
namespace BlackMisc::Weather
{
CTemperatureLayer::CTemperatureLayer(const CAltitude &level,
const CTemperature &value,
const CTemperature &dewPoint,
double relativeHumidity) : m_level(level), m_temperature(value), m_dewPoint(dewPoint), m_relativeHumidity(relativeHumidity)
{}
QVariant CTemperatureLayer::propertyByIndex(BlackMisc::CPropertyIndexRef index) const
{
if (index.isMyself()) { return QVariant::fromValue(*this); }
ColumnIndex i = index.frontCasted<ColumnIndex>();
switch (i)
{
case IndexLevel:
return QVariant::fromValue(m_level);
case IndexTemperature:
return QVariant::fromValue(m_temperature);
case IndexDewPoint:
return QVariant::fromValue(m_dewPoint);
case IndexRelativeHumidity:
return QVariant::fromValue(m_relativeHumidity);
default:
return CValueObject::propertyByIndex(index);
}
}
void CTemperatureLayer::setPropertyByIndex(CPropertyIndexRef index, const QVariant &variant)
{
if (index.isMyself())
{
(*this) = variant.value<CTemperatureLayer>();
return;
}
ColumnIndex i = index.frontCasted<ColumnIndex>();
switch (i)
{
case IndexLevel:
setLevel(variant.value<CAltitude>());
break;
case IndexTemperature:
setTemperature(variant.value<CTemperature>());
break;
case IndexDewPoint:
setDewPoint(variant.value<CTemperature>());
break;
case IndexRelativeHumidity:
setRelativeHumidity(variant.value<double>());
break;
default:
CValueObject::setPropertyByIndex(index, variant);
break;
}
}
QString CTemperatureLayer::convertToQString(bool /** i18n **/) const
{
return QStringLiteral("%1 %2 at %3").arg(m_temperature.toQString(), QString::number(m_relativeHumidity), m_level.toQString());
}
} // namespace