summaryrefslogtreecommitdiffstats
path: root/qt-ui/profile/diveeventitem.cpp
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@intel.com>2014-02-15 21:05:47 -0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-02-15 17:15:14 -0800
commit87d528992052ccc6204a25642b503a15ab45f9f9 (patch)
treee36f45855771a7df85eaa33719ba1289cbae5365 /qt-ui/profile/diveeventitem.cpp
parent6c67f90858aaccddc848e94ea161e284456e94d3 (diff)
downloadsubsurface-87d528992052ccc6204a25642b503a15ab45f9f9.tar.gz
Move the events when a partial pressure graph is enabled / disabled
The events were static on the canvas even if the profile changed its size because of a toggle of the partial pressure gas. This patch makes events move on the canvas to their correct place. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/profile/diveeventitem.cpp')
-rw-r--r--qt-ui/profile/diveeventitem.cpp18
1 files changed, 12 insertions, 6 deletions
diff --git a/qt-ui/profile/diveeventitem.cpp b/qt-ui/profile/diveeventitem.cpp
index 2250a7306..e744e6a0f 100644
--- a/qt-ui/profile/diveeventitem.cpp
+++ b/qt-ui/profile/diveeventitem.cpp
@@ -1,6 +1,7 @@
#include "diveeventitem.h"
#include "diveplotdatamodel.h"
#include "divecartesianaxis.h"
+#include "animationfunctions.h"
#include "dive.h"
#include <QDebug>
@@ -14,19 +15,20 @@ DiveEventItem::DiveEventItem(QObject* parent): DivePixmapItem(parent),
void DiveEventItem::setHorizontalAxis(DiveCartesianAxis* axis)
{
hAxis = axis;
- recalculatePos();
+ recalculatePos(true);
}
void DiveEventItem::setModel(DivePlotDataModel* model)
{
dataModel = model;
- recalculatePos();
+ recalculatePos(true);
}
void DiveEventItem::setVerticalAxis(DiveCartesianAxis* axis)
{
vAxis = axis;
- recalculatePos();
+ recalculatePos(true);
+ connect(vAxis, SIGNAL(sizeChanged()), this, SLOT(recalculatePos()));
}
void DiveEventItem::setEvent(struct event* ev)
@@ -34,7 +36,7 @@ void DiveEventItem::setEvent(struct event* ev)
internalEvent = ev;
setupPixmap();
setupToolTipString();
- recalculatePos();
+ recalculatePos(true);
}
void DiveEventItem::setupPixmap()
@@ -101,7 +103,7 @@ void DiveEventItem::eventVisibilityChanged(const QString& eventName, bool visibl
{
}
-void DiveEventItem::recalculatePos()
+void DiveEventItem::recalculatePos(bool instant)
{
if (!vAxis || !hAxis || !internalEvent || !dataModel) {
return;
@@ -117,5 +119,9 @@ void DiveEventItem::recalculatePos()
int depth = dataModel->data(dataModel->index(result.first().row(), DivePlotDataModel::DEPTH)).toInt();
qreal x = hAxis->posAtValue(internalEvent->time.seconds);
qreal y = vAxis->posAtValue(depth);
- setPos(x, y);
+ if (!instant){
+ Animations::moveTo(this, x, y, 500);
+ }else{
+ setPos(x,y);
+ }
}