This repository has been archived on 2026-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
powersync-app/libnymea-app/models/xyseriesadapter.h
2025-12-05 13:39:19 +01:00

125 lines
3.8 KiB
C++

// SPDX-License-Identifier: LGPL-3.0-or-later
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright (C) 2013 - 2024, nymea GmbH
* Copyright (C) 2024 - 2025, chargebyte austria GmbH
*
* This file is part of libnymea-app.
*
* libnymea-app is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3
* of the License, or (at your option) any later version.
*
* libnymea-app 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 libnymea-app. If not, see <https://www.gnu.org/licenses/>.
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#ifndef XYSERIESADAPTER_H
#define XYSERIESADAPTER_H
#include "logsmodel.h"
#include <QObject>
#include <QXYSeries>
#if QT_VERSION < QT_VERSION_CHECK(6, 0 ,0)
using namespace QtCharts;
#endif
class XYSeriesAdapter : public QObject
{
Q_OBJECT
Q_PROPERTY(LogsModel* logsModel READ logsModel WRITE setLogsModel NOTIFY logsModelChanged)
Q_PROPERTY(QXYSeries* xySeries READ xySeries WRITE setXySeries NOTIFY xySeriesChanged)
Q_PROPERTY(QXYSeries* baseSeries READ baseSeries WRITE setBaseSeries NOTIFY baseSeriesChanged)
Q_PROPERTY(SampleRate sampleRate READ sampleRate WRITE setSampleRate NOTIFY sampleRateChanged)
Q_PROPERTY(bool smooth READ smooth WRITE setSmooth NOTIFY smoothChanged)
Q_PROPERTY(bool inverted READ inverted WRITE setInverted NOTIFY invertedChanged)
Q_PROPERTY(qreal maxValue READ maxValue NOTIFY maxValueChanged)
Q_PROPERTY(qreal minValue READ minValue NOTIFY minValueChanged)
public:
enum SampleRate {
SampleRateSecond = 1,
SampleRateMinute = 60,
SampleRate10Minutes = 60 * 10,
SampleRateHour = 60 * 60,
SampleRateDays = 24 * 60 * 60
};
Q_ENUM(SampleRate)
explicit XYSeriesAdapter(QObject *parent = nullptr);
LogsModel* logsModel() const;
void setLogsModel(LogsModel *logsModel);
QXYSeries* xySeries() const;
void setXySeries(QXYSeries *series);
QXYSeries* baseSeries() const;
void setBaseSeries(QXYSeries *series);
SampleRate sampleRate() const;
void setSampleRate(SampleRate sampleRate);
bool smooth() const;
void setSmooth(bool smooth);
bool inverted() const;
void setInverted(bool inverted);
qreal maxValue() const;
qreal minValue() const;
Q_INVOKABLE void ensureSamples(const QDateTime &from, const QDateTime &to);
signals:
void xySeriesChanged();
void logsModelChanged();
void baseSeriesChanged();
void sampleRateChanged();
void smoothChanged();
void invertedChanged();
void maxValueChanged();
void minValueChanged();
private slots:
void logEntryAdded(LogEntry *entry);
private:
qreal calculateSampleValue(int index);
private:
class Sample {
public:
QDateTime timestamp; // The timestamp where this sample *ends*
QVector<LogEntry*> entries; // all log entries in this sample, that is, from timestamp - smaple size to timestamp
LogEntry *startingPoint = nullptr; // the starting point for the sample. Normally the last entry of the previous sample
};
LogsModel* m_model = nullptr;
QXYSeries* m_series = nullptr;
QXYSeries* m_baseSeries = nullptr;
SampleRate m_sampleRate = SampleRateSecond;
bool m_smooth = true;
bool m_inverted = false;
QVector<Sample*> m_samples;
QDateTime m_newestSample;
QDateTime m_oldestSample;
qreal m_maxValue = 0;
qreal m_minValue = 0;
};
#endif // XYSERIESADAPTER_H