From 87e380c7a28b467705b470323275db3812e0fa90 Mon Sep 17 00:00:00 2001 From: Tomaz Canabrava Date: Mon, 17 Jun 2013 21:05:17 -0300 Subject: Yearly stats are being displayed. Yearly stats are being displayed. the code is similar to the GTK one, but I advise the reader that it's a bit risky ( I got an unreproducible crash but it seems to be fixed now. ). The selection behavior is *weird* and I have no idea why, but I'm very sleepy - will try to look at it again tomorrow. Signed-off-by: Tomaz Canabrava --- qt-ui/mainwindow.cpp | 2 +- qt-ui/models.cpp | 83 +++++++++++++++++++++++++++++++++++++++++++++++++++- qt-ui/models.h | 1 + 3 files changed, 84 insertions(+), 2 deletions(-) diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp index ae43ff814..ca6fa4113 100644 --- a/qt-ui/mainwindow.cpp +++ b/qt-ui/mainwindow.cpp @@ -241,7 +241,7 @@ void MainWindow::on_actionToggleZoom_triggered() void MainWindow::on_actionYearlyStatistics_triggered() { - QTableView *view = new QTableView(); + QTreeView *view = new QTreeView(); QAbstractItemModel *model = new YearlyStatisticsModel(); view->setModel(model); view->show(); diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp index f2dcc3cd9..2de8ababa 100644 --- a/qt-ui/models.cpp +++ b/qt-ui/models.cpp @@ -8,6 +8,8 @@ #include "../helpers.h" #include "../dive.h" #include "../device.h" +#include "../statistics.h" + #include #include @@ -1282,9 +1284,70 @@ void DiveComputerModel::remove(const QModelIndex& i) * ################################################################ */ +class YearStatisticsItem : public TreeItem{ +public: + enum { YEAR,DIVES,TOTAL_TIME,AVERAGE_TIME,SHORTEST_TIME,LONGEST_TIME,AVG_DEPTH,MIN_DEPTH, + MAX_DEPTH,AVG_SAC,MIN_SAC,MAX_SAC,AVG_TEMP,MIN_TEMP,MAX_TEMP,COLUMNS}; + + QVariant data(int column, int role) const; + YearStatisticsItem(stats_t interval); +private: + stats_t stats_interval; +}; + +YearStatisticsItem::YearStatisticsItem(stats_t interval) +: stats_interval(interval) +{ +} + +QVariant YearStatisticsItem::data(int column, int role) const +{ + const char *unit; + QVariant ret; + + if (role != Qt::DisplayRole){ + return ret; + } + + switch(column){ + case YEAR: ret = stats_interval.period; break; + case DIVES: ret = stats_interval.selection_size;break; + case TOTAL_TIME: ret = get_time_string(stats_interval.total_time.seconds, 0);break; + case AVERAGE_TIME: ret = get_minutes(stats_interval.total_time.seconds / stats_interval.selection_size);break; + case SHORTEST_TIME: ret = get_minutes(stats_interval.shortest_time.seconds);break; + case LONGEST_TIME: ret = get_minutes(stats_interval.longest_time.seconds);break; + case AVG_DEPTH: ret = stats_interval.avg_depth.mm;break; + case MIN_DEPTH: ret = stats_interval.min_depth.mm;break; + case MAX_DEPTH: ret = stats_interval.max_depth.mm;break; + case AVG_SAC: ret = stats_interval.avg_sac.mliter;break; + case MIN_SAC: ret = stats_interval.min_sac.mliter;break; + case MAX_SAC: ret = stats_interval.max_sac.mliter;break; + case AVG_TEMP:{ + get_temp_units(stats_interval.min_temp, &unit); + if (stats_interval.combined_temp && stats_interval.combined_count) { + ret = QString("%1 %2").arg(stats_interval.combined_temp / stats_interval.combined_count).arg(unit); + } + }break; + case MIN_TEMP:{ + double value = get_temp_units(stats_interval.min_temp, &unit); + if (value > -100.0) { + ret = QString("%1 %2").arg(value).arg(unit); + } + }break; + case MAX_TEMP:{ + double value = get_temp_units(stats_interval.max_temp, &unit); + if (value > -100.0) { + ret = QString("%1 %2").arg(value).arg(unit); + } + }break; + } + return ret; +} + YearlyStatisticsModel::YearlyStatisticsModel(QObject* parent) { columns = COLUMNS; + update_yearly_stats(); } QVariant YearlyStatisticsModel::headerData(int section, Qt::Orientation orientation, int role) const @@ -1293,7 +1356,7 @@ QVariant YearlyStatisticsModel::headerData(int section, Qt::Orientation orientat if (role == Qt::FontRole){ val = defaultModelFont(); } - + if (role == Qt::DisplayRole && orientation == Qt::Horizontal){ switch(section){ case YEAR: val = tr("Year \n > Month"); break; @@ -1315,3 +1378,21 @@ QVariant YearlyStatisticsModel::headerData(int section, Qt::Orientation orientat } return val; } + +void YearlyStatisticsModel::update_yearly_stats() +{ + int i, month = 0; + unsigned int j, combined_months; + + for (i = 0; stats_yearly != NULL && stats_yearly[i].period; ++i){ + YearStatisticsItem *item = new YearStatisticsItem(stats_yearly[i]); + combined_months = 0; + for (j = 0; combined_months < stats_yearly[i].selection_size; ++j) { + combined_months += stats_monthly[month].selection_size; + YearStatisticsItem *iChild = new YearStatisticsItem(stats_monthly[month]); + item->children.append(iChild); + month++; + } + rootItem->children.append(item); + } +} diff --git a/qt-ui/models.h b/qt-ui/models.h index 4e84aa9b2..30d4b3a17 100644 --- a/qt-ui/models.h +++ b/qt-ui/models.h @@ -204,5 +204,6 @@ public: virtual QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const; YearlyStatisticsModel(QObject* parent = 0); + void update_yearly_stats(); }; #endif -- cgit v1.2.3-70-g09d2