summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/profile/profilewidget2.cpp64
-rw-r--r--qt-ui/profile/profilewidget2.h15
2 files changed, 42 insertions, 37 deletions
diff --git a/qt-ui/profile/profilewidget2.cpp b/qt-ui/profile/profilewidget2.cpp
index a13b3ee5d..061beefb0 100644
--- a/qt-ui/profile/profilewidget2.cpp
+++ b/qt-ui/profile/profilewidget2.cpp
@@ -22,23 +22,31 @@
#endif
#include "mainwindow.h"
-namespace ItemPos{
- int backgroundOnCanvas;
- int backgroundOffCanvas;
- int profileYAxisOnCanvas;
- int profileYAxisOffCanvas;
- // unused so far:
- int gasYAxisOnCanvas;
- int depthControllerOnCanvas;
- int timeControllerOnCanvas;
- int gasYAxisOffCanvas;
- int timeAxisOnCanvas;
- int timeAxisOffCanvas;
- int timeAxisEditMode;
- int depthControllerOffCanvas;
- int timeControllerOffCanvas;
- QLineF profileYAxisExpanded;
-}
+/* This is the global 'Item position' variable.
+ * it should tell you where to position things up
+ * on the canvas.
+ *
+ * please, please, please, use this instead of
+ * hard coding the item on the scene with a random
+ * value.
+ */
+static struct _ItemPos{
+ struct _Pos{
+ QPointF on;
+ QPointF off;
+ };
+ struct _Axis{
+ _Pos pos;
+ QLineF shrinked;
+ QLineF expanded;
+ };
+ _Pos background;
+ _Axis depth;
+ _Axis partialgas;
+ _Axis time;
+ _Axis cylinder;
+ _Axis temperature;
+} itemPos;
ProfileWidget2::ProfileWidget2(QWidget *parent) :
QGraphicsView(parent),
@@ -51,8 +59,6 @@ ProfileWidget2::ProfileWidget2(QWidget *parent) :
gasYAxis(new PartialGasPressureAxis()),
temperatureAxis(new TemperatureAxis()),
timeAxis(new TimeAxis()),
- depthController(new DiveRectItem()),
- timeController(new DiveRectItem()),
diveProfileItem(new DiveProfileItem()),
cylinderPressureAxis(new DiveCartesianAxis()),
temperatureItem(new DiveTemperatureItem()),
@@ -87,8 +93,6 @@ void ProfileWidget2::addItemsToScene()
scene()->addItem(gasYAxis);
scene()->addItem(temperatureAxis);
scene()->addItem(timeAxis);
- scene()->addItem(depthController);
- scene()->addItem(timeController);
scene()->addItem(diveProfileItem);
scene()->addItem(cylinderPressureAxis);
scene()->addItem(temperatureItem);
@@ -131,9 +135,6 @@ void ProfileWidget2::setupItemOnScene()
cylinderPressureAxis->setTickSize(2);
cylinderPressureAxis->setTickInterval(30000);
- depthController->setRect(0, 0, 10, 5);
- timeController->setRect(0, 0, 10, 5);
- timeController->setX(sceneRect().width() - timeController->boundingRect().width()); // Position it on the right spot.
meanDepth->setLine(0,0,96,0);
meanDepth->setX(3);
meanDepth->setPen(QPen(QBrush(Qt::red), 0, Qt::SolidLine));
@@ -173,7 +174,11 @@ void ProfileWidget2::setupItemOnScene()
void ProfileWidget2::setupItemSizes()
{
-
+ // Scene is *always* 100 / 100.
+ itemPos.background.on.setX(0);
+ itemPos.background.on.setY(0);
+ itemPos.background.off.setX(0);
+ itemPos.background.off.setY(110);
}
void ProfileWidget2::setupItem(AbstractProfilePolygonItem* item, DiveCartesianAxis* hAxis, DiveCartesianAxis* vAxis, DivePlotDataModel* model, int vData, int hData, int zValue)
@@ -290,7 +295,9 @@ void ProfileWidget2::settingsChanged()
void ProfileWidget2::resizeEvent(QResizeEvent* event)
{
- QGraphicsView::resizeEvent(event);
+ QGraphicsView::resizeEvent(event); DiveRectItem *depthController;
+ DiveRectItem *timeController;
+
fitInView(sceneRect(), Qt::IgnoreAspectRatio);
}
@@ -301,9 +308,8 @@ void ProfileWidget2::fixBackgroundPos()
return;
QPixmap p = toBeScaled.scaledToHeight(viewport()->height());
int x = viewport()->width() / 2 - p.width() / 2;
- DivePixmapItem *bg = background;
- bg->setPixmap(p);
- bg->setX(mapToScene(x, 0).x());
+ background->setPixmap(p);
+ background->setX(mapToScene(x, 0).x());
}
void ProfileWidget2::wheelEvent(QWheelEvent* event)
diff --git a/qt-ui/profile/profilewidget2.h b/qt-ui/profile/profilewidget2.h
index 088e33f8c..b837376d3 100644
--- a/qt-ui/profile/profilewidget2.h
+++ b/qt-ui/profile/profilewidget2.h
@@ -44,12 +44,6 @@ struct AbstractProfilePolygonItem;
class ProfileWidget2 : public QGraphicsView {
Q_OBJECT
- void fixBackgroundPos();
- void scrollViewTo(const QPoint& pos);
- void setupSceneAndFlags();
- void setupItemSizes();
- void addItemsToScene();
- void setupItemOnScene();
public:
enum State{ EMPTY, PROFILE, EDIT, ADD, PLAN, INVALID };
enum Items{BACKGROUND, PROFILE_Y_AXIS, GAS_Y_AXIS, TIME_AXIS, DEPTH_CONTROLLER, TIME_CONTROLLER, COLUMNS};
@@ -69,6 +63,13 @@ protected:
signals:
void startProfileState();
void startEmptyState();
+private: /*methods*/
+ void fixBackgroundPos();
+ void scrollViewTo(const QPoint& pos);
+ void setupSceneAndFlags();
+ void setupItemSizes();
+ void addItemsToScene();
+ void setupItemOnScene();
private:
DivePlotDataModel *dataModel;
State currentState;
@@ -83,8 +84,6 @@ private:
PartialGasPressureAxis *gasYAxis;
TemperatureAxis *temperatureAxis;
TimeAxis *timeAxis;
- DiveRectItem *depthController;
- DiveRectItem *timeController;
DiveProfileItem *diveProfileItem;
DiveCartesianPlane *cartesianPlane;
DiveTemperatureItem *temperatureItem;