nymea-plugins/netatmo/netatmooutdoormodule.cpp

136 lines
3.9 KiB
C++

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright 2013 - 2020, nymea GmbH
* Contact: contact@nymea.io
*
* This file is part of nymea.
* This project including source code and documentation is protected by
* copyright law, and remains the property of nymea GmbH. All rights, including
* reproduction, publication, editing and translation, are reserved. The use of
* this project is subject to the terms of a license agreement to be concluded
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
* under https://nymea.io/license
*
* GNU Lesser General Public License Usage
* Alternatively, this project may be redistributed and/or modified under the
* terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; version 3. This project is distributed in the hope that
* it will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this project. If not, see <https://www.gnu.org/licenses/>.
*
* For any further details and any questions please contact us under
* contact@nymea.io or see our FAQ/Licensing Information on
* https://nymea.io/license/faq
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "netatmooutdoormodule.h"
#include <QVariantMap>
NetatmoOutdoorModule::NetatmoOutdoorModule(const QString &name, const QString &macAddress, const QString &baseStation, QObject *parent) :
QObject(parent),
m_name(name),
m_macAddress(macAddress),
m_baseStation(baseStation)
{
}
QString NetatmoOutdoorModule::name() const
{
return m_name;
}
QString NetatmoOutdoorModule::macAddress() const
{
return m_macAddress;
}
QString NetatmoOutdoorModule::baseStation() const
{
return m_baseStation;
}
int NetatmoOutdoorModule::lastUpdate() const
{
return m_lastUpdate;
}
int NetatmoOutdoorModule::humidity() const
{
return m_humidity;
}
double NetatmoOutdoorModule::temperature() const
{
return m_temperature;
}
double NetatmoOutdoorModule::minTemperature() const
{
return m_minTemperature;
}
double NetatmoOutdoorModule::maxTemperature() const
{
return m_maxTemperature;
}
int NetatmoOutdoorModule::signalStrength() const
{
return m_signalStrength;
}
int NetatmoOutdoorModule::battery() const
{
return m_battery;
}
void NetatmoOutdoorModule::updateStates(const QVariantMap &data)
{
// check data timestamp
if (data.contains("last_message")) {
m_lastUpdate = data.value("last_message").toInt();
}
// update dashboard data
if (data.contains("dashboard_data")) {
QVariantMap measurments = data.value("dashboard_data").toMap();
m_humidity = measurments.value("Humidity").toInt();
m_temperature = measurments.value("Temperature").toDouble();
m_minTemperature = measurments.value("min_temp").toDouble();
m_maxTemperature = measurments.value("max_temp").toDouble();
}
// update battery strength
if (data.contains("battery_vp")) {
int battery = data.value("battery_vp").toInt();
if (battery >= 6000) {
m_battery = 100;
} else if (battery <= 3600) {
m_battery = 0;
} else {
int delta = battery - 3600;
m_battery = qRound(100.0 * delta / 2400);
}
}
// update signal strength
if (data.contains("rf_status")) {
int signalStrength = data.value("rf_status").toInt();
if (signalStrength <= 60) {
m_signalStrength = 100;
} else if (signalStrength >= 90) {
m_signalStrength = 0;
} else {
int delta = 30 - (signalStrength - 60);
m_signalStrength = qRound(100.0 * delta / 30.0);
}
}
emit statesChanged();
}