summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tcanabrava@kde.org>2014-02-07 14:14:36 -0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-02-08 07:14:50 -0800
commit6de9b329d16275573d2e8f2ea6e712c626553dad (patch)
tree83f45403f14ecab13bebf5f401149e3e21e296c1
parent361f8ede76f451a383550387e29f63173149c887 (diff)
downloadsubsurface-6de9b329d16275573d2e8f2ea6e712c626553dad.tar.gz
Huge code cleanup.
This patch starts the cleanup that will take a few iterations to finish. The current profile code uses QStateMachine, and it's much too verbose for something we can do with less than a third of its lines of code. I also added on the beginning of the redesign of the profile code for planner, edit and a few other things that are going to be ported to the new profile in the future, but not currently - I just lack the time to make that work for the next release. This commit basically: - moves all 'new' calls to the initializer-list - create a new 'setupItem' private method to concentrate the calls that any item will do Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/profile/profilewidget2.cpp89
-rw-r--r--qt-ui/profile/profilewidget2.h2
2 files changed, 28 insertions, 63 deletions
diff --git a/qt-ui/profile/profilewidget2.cpp b/qt-ui/profile/profilewidget2.cpp
index 4ebc8c3ee..1692048a0 100644
--- a/qt-ui/profile/profilewidget2.cpp
+++ b/qt-ui/profile/profilewidget2.cpp
@@ -36,15 +36,15 @@ ProfileWidget2::ProfileWidget2(QWidget *parent) :
timeAxis(new TimeAxis()),
depthController(new DiveRectItem()),
timeController(new DiveRectItem()),
- diveProfileItem(NULL),
+ diveProfileItem(new DiveProfileItem()),
cylinderPressureAxis(new DiveCartesianAxis()),
- temperatureItem(NULL),
- gasPressureItem(NULL),
+ temperatureItem(new DiveTemperatureItem()),
+ gasPressureItem(new DiveGasPressureItem()),
cartesianPlane(new DiveCartesianPlane()),
meanDepth(new MeanDepthLine()),
diveComputerText(new DiveTextItem()),
- diveCeiling(NULL),
- reportedCeiling(NULL)
+ diveCeiling(new DiveCalculatedCeiling()),
+ reportedCeiling(new DiveReportedCeiling())
{
setScene(new QGraphicsScene());
scene()->setSceneRect(0, 0, 100, 100);
@@ -124,76 +124,26 @@ ProfileWidget2::ProfileWidget2(QWidget *parent) :
scene()->addItem(item);
}
- reportedCeiling = new DiveReportedCeiling();
- reportedCeiling->setHorizontalAxis(timeAxis);
- reportedCeiling->setVerticalAxis(profileYAxis);
- reportedCeiling->setModel(dataModel);
- reportedCeiling->setVerticalDataColumn(DivePlotDataModel::CEILING);
- reportedCeiling->setHorizontalDataColumn(DivePlotDataModel::TIME);
- reportedCeiling->setZValue(1);
- scene()->addItem(reportedCeiling);
-
- diveCeiling = new DiveCalculatedCeiling();
- diveCeiling->setHorizontalAxis(timeAxis);
- diveCeiling->setVerticalAxis(profileYAxis);
- diveCeiling->setModel(dataModel);
- diveCeiling->setVerticalDataColumn(DivePlotDataModel::CEILING);
- diveCeiling->setHorizontalDataColumn(DivePlotDataModel::TIME);
- diveCeiling->setZValue(1);
- scene()->addItem(diveCeiling);
+ setupItem(reportedCeiling, timeAxis, profileYAxis, dataModel, DivePlotDataModel::CEILING, DivePlotDataModel::TIME, 1);
+ setupItem(diveCeiling, timeAxis, profileYAxis, dataModel, DivePlotDataModel::CEILING, DivePlotDataModel::TIME, 1);
for(int i = 0; i < 16; i++){
DiveCalculatedTissue *tissueItem = new DiveCalculatedTissue();
- tissueItem->setHorizontalAxis(timeAxis);
- tissueItem->setVerticalAxis(profileYAxis);
- tissueItem->setModel(dataModel);
- tissueItem->setVerticalDataColumn(DivePlotDataModel::TISSUE_1 + i);
- tissueItem->setHorizontalDataColumn(DivePlotDataModel::TIME);
- tissueItem->setZValue(1);
+ setupItem(tissueItem, timeAxis, profileYAxis, dataModel, DivePlotDataModel::TISSUE_1 + i, DivePlotDataModel::TIME, 1+i);
allTissues.append(tissueItem);
- scene()->addItem(tissueItem);
}
- gasPressureItem = new DiveGasPressureItem();
- gasPressureItem->setHorizontalAxis(timeAxis);
- gasPressureItem->setVerticalAxis(cylinderPressureAxis);
- gasPressureItem->setModel(dataModel);
- gasPressureItem->setVerticalDataColumn(DivePlotDataModel::TEMPERATURE);
- gasPressureItem->setHorizontalDataColumn(DivePlotDataModel::TIME);
- gasPressureItem->setZValue(1);
- scene()->addItem(gasPressureItem);
-
- temperatureItem = new DiveTemperatureItem();
- temperatureItem->setHorizontalAxis(timeAxis);
- temperatureItem->setVerticalAxis(temperatureAxis);
- temperatureItem->setModel(dataModel);
- temperatureItem->setVerticalDataColumn(DivePlotDataModel::TEMPERATURE);
- temperatureItem->setHorizontalDataColumn(DivePlotDataModel::TIME);
- temperatureItem->setZValue(1);
- scene()->addItem(temperatureItem);
-
- diveProfileItem = new DiveProfileItem();
- diveProfileItem->setHorizontalAxis(timeAxis);
- diveProfileItem->setVerticalAxis(profileYAxis);
- diveProfileItem->setModel(dataModel);
- diveProfileItem->setVerticalDataColumn(DivePlotDataModel::DEPTH);
- diveProfileItem->setHorizontalDataColumn(DivePlotDataModel::TIME);
- diveProfileItem->setZValue(0);
- scene()->addItem(diveProfileItem);
+ setupItem(gasPressureItem, timeAxis, cylinderPressureAxis, dataModel, DivePlotDataModel::TEMPERATURE, DivePlotDataModel::TIME, 1);
+ setupItem(temperatureItem, timeAxis, temperatureAxis, dataModel, DivePlotDataModel::TEMPERATURE, DivePlotDataModel::TIME, 1);
+ setupItem(diveProfileItem, timeAxis, profileYAxis, dataModel, DivePlotDataModel::DEPTH, DivePlotDataModel::TIME, 0);
#define CREATE_PP_GAS( ITEM, VERTICAL_COLUMN, COLOR, COLOR_ALERT, THRESHOULD_SETTINGS, VISIBILITY_SETTINGS ) \
ITEM = new PartialPressureGasItem(); \
- ITEM->setHorizontalAxis(timeAxis); \
- ITEM->setVerticalAxis(gasYAxis); \
- ITEM->setModel(dataModel); \
- ITEM->setVerticalDataColumn(DivePlotDataModel::VERTICAL_COLUMN); \
- ITEM->setHorizontalDataColumn(DivePlotDataModel::TIME); \
- ITEM->setZValue(0); \
+ setupItem(ITEM, timeAxis, gasYAxis, dataModel, DivePlotDataModel::VERTICAL_COLUMN, DivePlotDataModel::TIME, 0); \
ITEM->setThreshouldSettingsKey(THRESHOULD_SETTINGS); \
ITEM->setVisibilitySettingsKey(VISIBILITY_SETTINGS); \
ITEM->setColors(getColor(COLOR), getColor(COLOR_ALERT)); \
- ITEM->preferencesChanged(); \
- scene()->addItem(ITEM);
+ ITEM->preferencesChanged();
CREATE_PP_GAS( pn2GasItem, PN2, PN2, PN2_ALERT, "pn2threshold", "pn2graph");
CREATE_PP_GAS( pheGasItem, PHE, PHE, PHE_ALERT, "phethreshold", "phegraph");
@@ -300,6 +250,17 @@ ProfileWidget2::ProfileWidget2(QWidget *parent) :
mainWindow()->tabWidget()->addTab(diveDepthTableView, "Depth Model");
#endif
}
+void ProfileWidget2::setupItem(AbstractProfilePolygonItem* item, DiveCartesianAxis* hAxis, DiveCartesianAxis* vAxis, DivePlotDataModel* model, int vData, int hData, int zValue)
+{
+ item->setHorizontalAxis(hAxis);
+ item->setVerticalAxis(vAxis);
+ item->setModel(model);
+ item->setVerticalDataColumn(vData);
+ item->setHorizontalDataColumn(hData);
+ item->setZValue(zValue);
+ scene()->addItem(item);
+}
+
// Currently just one dive, but the plan is to enable All of the selected dives.
void ProfileWidget2::plotDives(QList<dive*> dives)
@@ -310,7 +271,9 @@ void ProfileWidget2::plotDives(QList<dive*> dives)
if (!d)
return;
+ if ((*stateMachine->configuration().begin())->objectName() != "Profile State") {
emit startProfileState();
+ }
// Here we need to probe for the limits of the dive.
// There's already a function that does exactly that,
diff --git a/qt-ui/profile/profilewidget2.h b/qt-ui/profile/profilewidget2.h
index 631a80574..237fc21b5 100644
--- a/qt-ui/profile/profilewidget2.h
+++ b/qt-ui/profile/profilewidget2.h
@@ -40,6 +40,7 @@ struct DiveReportedCeiling;
struct DiveCalculatedTissue;
struct PartialPressureGasItem;
struct PartialGasPressureAxis;
+struct AbstractProfilePolygonItem;
class ProfileWidget2 : public QGraphicsView {
Q_OBJECT
@@ -52,6 +53,7 @@ public:
ProfileWidget2(QWidget *parent);
void plotDives(QList<dive*> dives);
virtual bool eventFilter(QObject*, QEvent*);
+ void setupItem( AbstractProfilePolygonItem *item, DiveCartesianAxis *hAxis, DiveCartesianAxis *vAxis, DivePlotDataModel *model, int vData, int hData, int zValue);
public slots: // Necessary to call from QAction's signals.
void settingsChanged();