summaryrefslogtreecommitdiffstats
path: root/mobile-widgets
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2021-01-12 10:28:04 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2021-01-13 11:39:36 -0800
commit12842f4a86761569d867e54a523a586409a03dc5 (patch)
tree64e95fcc0f8b1fd171d98e0ea1f1393441ef9123 /mobile-widgets
parente610fb248115cb70bc3ded65ad3ac6985658a4a9 (diff)
downloadsubsurface-12842f4a86761569d867e54a523a586409a03dc5.tar.gz
mobile/statistics: make charts model available to UI
Create a QML ChartListModel in the StatisticsPage and pass that to the StatsManager on initialization. [extracted from a slightly larger commit] Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'mobile-widgets')
-rw-r--r--mobile-widgets/statsmanager.cpp20
-rw-r--r--mobile-widgets/statsmanager.h6
2 files changed, 20 insertions, 6 deletions
diff --git a/mobile-widgets/statsmanager.cpp b/mobile-widgets/statsmanager.cpp
index 54fc804fd..a49259ff9 100644
--- a/mobile-widgets/statsmanager.cpp
+++ b/mobile-widgets/statsmanager.cpp
@@ -1,7 +1,8 @@
// SPDX-License-Identifier: GPL-2.0
#include "statsmanager.h"
+#include "stats/chartlistmodel.h"
-StatsManager::StatsManager() : view(nullptr)
+StatsManager::StatsManager() : view(nullptr), charts(nullptr)
{
updateUi();
}
@@ -10,18 +11,19 @@ StatsManager::~StatsManager()
{
}
-void StatsManager::init(StatsView *v, QObject *o)
+void StatsManager::init(StatsView *v, ChartListModel *m)
{
if (!v)
fprintf(stderr, "StatsManager::init(): no StatsView - statistics will not work.\n");
+ if (!m)
+ fprintf(stderr, "StatsManager::init(): no ChartListModel - statistics will not work.\n");
view = v;
+ charts = m;
}
void StatsManager::doit()
{
- if (!view)
- return;
- view->plot(state);
+ updateUi();
}
static void setVariableList(const StatsState::VariableList &list, QStringList &stringList, int &idx)
@@ -59,6 +61,8 @@ void StatsManager::updateUi()
binner2IndexChanged();
operation2IndexChanged();
+ if (charts)
+ charts->update(uiState.charts);
if (view)
view->plot(state);
}
@@ -101,3 +105,9 @@ void StatsManager::var2OperationChanged(int idx)
state.var2OperationChanged(uiState.operations2.variables[idx].id);
updateUi();
}
+
+void StatsManager::setChart(int idx)
+{
+ state.chartChanged(idx);
+ updateUi();
+}
diff --git a/mobile-widgets/statsmanager.h b/mobile-widgets/statsmanager.h
index 82c7a6b89..6023342ff 100644
--- a/mobile-widgets/statsmanager.h
+++ b/mobile-widgets/statsmanager.h
@@ -7,6 +7,8 @@
#include <QStringList>
+class ChartListModel;
+
class StatsManager : public QObject {
Q_OBJECT
public:
@@ -23,13 +25,14 @@ public:
StatsManager();
~StatsManager();
- Q_INVOKABLE void init(StatsView *v, QObject *o);
+ Q_INVOKABLE void init(StatsView *v, ChartListModel *charts);
Q_INVOKABLE void doit();
Q_INVOKABLE void var1Changed(int idx);
Q_INVOKABLE void var1BinnerChanged(int idx);
Q_INVOKABLE void var2Changed(int idx);
Q_INVOKABLE void var2BinnerChanged(int idx);
Q_INVOKABLE void var2OperationChanged(int idx);
+ Q_INVOKABLE void setChart(int idx);
signals:
void var1ListChanged();
void binner1ListChanged();
@@ -43,6 +46,7 @@ signals:
void operation2IndexChanged();
private:
StatsView *view;
+ ChartListModel *charts;
StatsState state;
QStringList var1List;
QStringList binner1List;