diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2019-10-19 22:12:50 -0400 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-10-20 16:08:55 -0400 |
commit | 613a3112d27e2d40c3a4eeb7fb061f4739279157 (patch) | |
tree | 1cf0ba01a5c9af758897b7d5919e21822c2dfe94 /qt-models | |
parent | 09c7115e2192c30ee86007b1dcdec04134813751 (diff) | |
download | subsurface-613a3112d27e2d40c3a4eeb7fb061f4739279157.tar.gz |
Mobile: get dive details directly from the model
By getting a DiveObjectHelper and then dereferencing that we ended up
creating hundres and hundreds of these objects, only to immediately
destroy them after using a tiny part of the data.
Instead make those data available directly from the model, without
having to create a DiveObjectHelper forst.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-models')
-rw-r--r-- | qt-models/divelistmodel.cpp | 45 | ||||
-rw-r--r-- | qt-models/divelistmodel.h | 30 |
2 files changed, 74 insertions, 1 deletions
diff --git a/qt-models/divelistmodel.cpp b/qt-models/divelistmodel.cpp index d3c4e3ce2..d0a309330 100644 --- a/qt-models/divelistmodel.cpp +++ b/qt-models/divelistmodel.cpp @@ -1,5 +1,6 @@ // SPDX-License-Identifier: GPL-2.0 #include "qt-models/divelistmodel.h" +#include "core/divesite.h" #include "core/qthelper.h" #include "core/trip.h" #include "core/settings/qPrefGeneral.h" @@ -97,7 +98,7 @@ static dive_trip *tripIdToObject(const QString &s) return nullptr; int id = s.toInt(); dive_trip **trip = std::find_if(&trip_table.trips[0], &trip_table.trips[trip_table.nr], - [id] (const dive_trip *t) { return t->id == id; }); + [id] (const dive_trip *t) { return t->id == id; }); if (trip == &trip_table.trips[trip_table.nr]) { fprintf(stderr, "Warning: unknown trip id passed through QML: %d\n", id); return nullptr; @@ -256,8 +257,29 @@ QVariant DiveListModel::data(const QModelIndex &index, int role) const case IdRole: return d->id; case NumberRole: return d->number; case LocationRole: return get_dive_location(d); + case DepthRole: return get_depth_string(d->dc.maxdepth.mm, true, true); + case DurationRole: return get_dive_duration_string(d->duration.seconds, gettextFromC::tr("h"), gettextFromC::tr("min")); case DepthDurationRole: return QStringLiteral("%1 / %2").arg(get_depth_string(d->dc.maxdepth.mm, true, true), get_dive_duration_string(d->duration.seconds, gettextFromC::tr("h"), gettextFromC::tr("min"))); + case RatingRole: return d->rating; + case VizRole: return d->visibility; + case SuitRole: return d->suit; + case AirTempRole: return get_temperature_string(d->airtemp, true); + case WaterTempRole: return get_temperature_string(d->watertemp, true); + case SacRole: return formatSac(d); + case SumWeightRole: return get_weight_string(weight_t { total_weight(d) }, true); + case DiveMasterRole: return d->divemaster ? d->divemaster : QString(); + case BuddyRole: return d->buddy ? d->buddy : QString(); + case NotesRole: return formatNotes(d); + case GpsRole: return d->dive_site ? printGPSCoords(&d->dive_site->location) : QString(); + case GpsDecimalRole: return format_gps_decimal(d); + case NoDiveRole: return d->duration.seconds == 0 && d->dc.duration.seconds == 0; + case DiveSiteRole: return QVariant::fromValue(d->dive_site); + case CylinderRole: return formatGetCylinder(d).join(", "); + case SingleWeightRole: return d->weightsystems.nr <= 1; + case StartPressureRole: return getStartPressure(d); + case EndPressureRole: return getEndPressure(d); + case FirstGasRole: return getFirstGas(d); } return QVariant(); } @@ -273,7 +295,28 @@ QHash<int, QByteArray> DiveListModel::roleNames() const roles[IdRole] = "id"; roles[NumberRole] = "number"; roles[LocationRole] = "location"; + roles[DepthRole] = "depth"; + roles[DurationRole] = "duration"; roles[DepthDurationRole] = "depthDuration"; + roles[RatingRole] = "rating"; + roles[VizRole] = "viz"; + roles[SuitRole] = "suit"; + roles[AirTempRole] = "airTemp"; + roles[WaterTempRole] = "waterTemp"; + roles[SacRole] = "sac"; + roles[SumWeightRole] = "sumWeight"; + roles[DiveMasterRole] = "diveMaster"; + roles[BuddyRole] = "buddy"; + roles[NotesRole]= "notes"; + roles[GpsRole] = "gps"; + roles[GpsDecimalRole] = "gpsDecimal"; + roles[NoDiveRole] = "noDive"; + roles[DiveSiteRole] = "diveSite"; + roles[CylinderRole] = "cylinder"; + roles[SingleWeightRole] = "singleWeight"; + roles[StartPressureRole] = "startPressure"; + roles[EndPressureRole] = "endPressure"; + roles[FirstGasRole] = "firstGas"; return roles; } diff --git a/qt-models/divelistmodel.h b/qt-models/divelistmodel.h index 90cc51966..2f8985235 100644 --- a/qt-models/divelistmodel.h +++ b/qt-models/divelistmodel.h @@ -29,6 +29,15 @@ private: void updateFilterState(); }; +QString formatSac(const dive *d); +QString formatNotes(const dive *d); +QString format_gps_decimal(const dive *d); +QStringList formatGetCylinder(const dive *d); +QStringList getStartPressure(const dive *d); +QStringList getEndPressure(const dive *d); +QStringList getFirstGas(const dive *d); + + class DiveListModel : public QAbstractListModel { Q_OBJECT @@ -42,7 +51,28 @@ public: IdRole, NumberRole, LocationRole, + DepthRole, + DurationRole, DepthDurationRole, + RatingRole, + VizRole, + SuitRole, + AirTempRole, + WaterTempRole, + SacRole, + SumWeightRole, + DiveMasterRole, + BuddyRole, + NotesRole, + GpsDecimalRole, + GpsRole, + NoDiveRole, + DiveSiteRole, + CylinderRole, + SingleWeightRole, + StartPressureRole, + EndPressureRole, + FirstGasRole, }; static DiveListModel *instance(); |