#ifndef DIVEPLANNER_H #define DIVEPLANNER_H #include #include #include #include #include "dive.h" class QListView; class QModelIndex; class DivePlannerPointsModel : public QAbstractTableModel { Q_OBJECT public: static DivePlannerPointsModel *instance(); enum Sections { REMOVE, DEPTH, DURATION, RUNTIME, GAS, CCSETPOINT, COLUMNS }; enum Mode { NOTHING, PLAN, ADD }; virtual int columnCount(const QModelIndex &parent = QModelIndex()) const; virtual QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const; virtual int rowCount(const QModelIndex &parent = QModelIndex()) const; virtual QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const; virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole); virtual Qt::ItemFlags flags(const QModelIndex &index) const; void removeSelectedPoints(const QVector &rows); void setPlanMode(Mode mode); bool isPlanner(); void createSimpleDive(); void setupStartTime(); void clear(); Mode currentMode() const; bool setRecalc(bool recalc); bool recalcQ(); void tanksUpdated(); void rememberTanks(); bool tankInUse(struct gasmix gasmix); void setupCylinders(); /** * @return the row number. */ void editStop(int row, divedatapoint newData); divedatapoint at(int row); int size(); struct diveplan &getDiveplan(); QStringList &getGasList(); QVector > collectGases(dive *d); int lastEnteredPoint(); void removeDeco(); static bool addingDeco; public slots: int addStop(int millimeters = 0, int seconds = 0, struct gasmix *gas = 0, int ccpoint = 0, bool entered = true); void addCylinder_clicked(); void setGFHigh(const int gfhigh); void triggerGFHigh(); void setGFLow(const int ghflow); void triggerGFLow(); void setSurfacePressure(int pressure); void setSalinity(int salinity); int getSurfacePressure(); void setBottomSac(double sac); void setDecoSac(double sac); void setStartTime(const QTime &t); void setStartDate(const QDate &date); void setLastStop6m(bool value); void setDropStoneMode(bool value); void setVerbatim(bool value); void setDisplayRuntime(bool value); void setDisplayDuration(bool value); void setDisplayTransitions(bool value); void setRecreationalMode(bool value); void savePlan(); void saveDuplicatePlan(); void remove(const QModelIndex &index); void cancelPlan(); void createTemporaryPlan(); void deleteTemporaryPlan(); void loadFromDive(dive *d); void emitDataChanged(); void setRebreatherMode(int mode); signals: void planCreated(); void planCanceled(); void cylinderModelEdited(); void startTimeChanged(QDateTime); private: explicit DivePlannerPointsModel(QObject *parent = 0); bool addGas(struct gasmix mix); void createPlan(bool replanCopy); struct diveplan diveplan; Mode mode; bool recalc; QVector divepoints; QVector backupSamples; // For editing added dives. QVector > oldGases; QDateTime startTime; int tempGFHigh; int tempGFLow; }; class DiveHandler : public QObject, public QGraphicsEllipseItem { Q_OBJECT public: DiveHandler(); protected: void contextMenuEvent(QGraphicsSceneContextMenuEvent *event); void mouseMoveEvent(QGraphicsSceneMouseEvent *event); void mousePressEvent(QGraphicsSceneMouseEvent *event); void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); signals: void moved(); void clicked(); void released(); private: int parentIndex(); public slots: void selfRemove(); void changeGas(); private: QTime t; }; #include "ui_diveplanner.h" class DivePlannerWidget : public QWidget { Q_OBJECT public: explicit DivePlannerWidget(QWidget *parent = 0, Qt::WindowFlags f = 0); void setReplanButton(bool replan); public slots: void setupStartTime(QDateTime startTime); void settingsChanged(); void atmPressureChanged(const int pressure); void heightChanged(const int height); void salinityChanged(const double salinity); void printDecoPlan(); private: Ui::DivePlanner ui; QAbstractButton *replanButton; }; #include "ui_plannerSettings.h" class PlannerSettingsWidget : public QWidget { Q_OBJECT public: explicit PlannerSettingsWidget(QWidget *parent = 0, Qt::WindowFlags f = 0); virtual ~PlannerSettingsWidget(); public slots: void settingsChanged(); void atmPressureChanged(const QString &pressure); void bottomSacChanged(const double bottomSac); void decoSacChanged(const double decosac); void printDecoPlan(); void setAscRate75(int rate); void setAscRate50(int rate); void setAscRateStops(int rate); void setAscRateLast6m(int rate); void setDescRate(int rate); void setBottomPo2(double po2); void setDecoPo2(double po2); void setBackgasBreaks(bool dobreaks); private: Ui::plannerSettingsWidget ui; void updateUnitsUI(); }; #include "ui_plannerDetails.h" class PlannerDetails : public QWidget { Q_OBJECT public: explicit PlannerDetails(QWidget *parent = 0); QPushButton *printPlan() const { return ui.printPlan; } QTextEdit *divePlanOutput() const { return ui.divePlanOutput; } private: Ui::plannerDetails ui; }; QString dpGasToStr(const divedatapoint &p); #endif // DIVEPLANNER_H