summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/diveplanner.cpp88
-rw-r--r--qt-ui/diveplanner.h23
2 files changed, 86 insertions, 25 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index fad3080fd..643f35a2d 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -87,9 +87,9 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
timeLine->setColor(getColor(TIME_GRID));
timeLine->setLine(
fromPercent(10, Qt::Horizontal),
- fromPercent(90, Qt::Vertical),
+ fromPercent(85, Qt::Vertical),
fromPercent(90, Qt::Horizontal),
- fromPercent(90, Qt::Vertical)
+ fromPercent(85, Qt::Vertical)
);
timeLine->setOrientation(Qt::Horizontal);
timeLine->setTickSize(fromPercent(1, Qt::Vertical));
@@ -105,7 +105,7 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
fromPercent(10, Qt::Horizontal),
fromPercent(10, Qt::Vertical),
fromPercent(10, Qt::Horizontal),
- fromPercent(90, Qt::Vertical)
+ fromPercent(85, Qt::Vertical)
);
depthLine->setOrientation(Qt::Vertical);
depthLine->setTickSize(fromPercent(1, Qt::Horizontal));
@@ -128,26 +128,33 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
diveBg->setPen(QPen(QBrush(),0));
scene()->addItem(diveBg);
-#define ADDBTN(obj, icon, text, horizontal, vertical, tooltip, value, slot) \
- obj = new Button(); \
- obj->setPixmap(QPixmap(icon)); \
- obj->setPos(fromPercent(horizontal, Qt::Horizontal), fromPercent(vertical, Qt::Vertical)); \
- obj->setToolTip(QString(tooltip.arg(value))); \
- scene()->addItem(obj); \
- connect(obj, SIGNAL(clicked()), this, SLOT(slot));
-
QString incrText;
if (prefs.units.length == units::METERS)
incrText = tr("10m");
else
incrText = tr("30ft");
- ADDBTN(plusDepth, ":plus", "" , 5, 5, tr("Increase maximum depth by %1"), incrText, increaseDepth());
- ADDBTN(lessDepth, ":minimum","" , 2, 5, tr("Decreases maximum depth by %1"), incrText, decreaseDepth());
- ADDBTN(plusTime, ":plus", "" , 95, 95, tr("Increase minimum time by %1"), tr("10min"), increaseTime());
- ADDBTN(lessTime, ":minimum","" , 92, 95, tr("Decreases minimum time by %1"), tr("10min"), decreaseTime());
-#undef ADDBTN
- minMinutes = TIME_INITIAL_MAX;
+ timeHandler = new ExpanderGraphics();
+ timeHandler->increaseBtn->setPixmap(QString(":plan_plus"));
+ timeHandler->decreaseBtn->setPixmap(QString(":plan_minus"));
+ timeHandler->icon->setPixmap(QString(":icon_time"));
+ connect(timeHandler->increaseBtn, SIGNAL(clicked()), this, SLOT(increaseTime()));
+ connect(timeHandler->decreaseBtn, SIGNAL(clicked()), this, SLOT(decreaseTime()));
+ timeHandler->setPos(fromPercent(83, Qt::Horizontal), fromPercent(85, Qt::Vertical));
+ timeHandler->setZValue(-2);
+ scene()->addItem(timeHandler);
+
+ depthHandler = new ExpanderGraphics();
+ depthHandler->increaseBtn->setPixmap(QString(":arrow_up"));
+ depthHandler->decreaseBtn->setPixmap(QString(":arrow_down"));
+ depthHandler->icon->setPixmap(QString(":icon_depth"));
+ connect(depthHandler->increaseBtn, SIGNAL(clicked()), this, SLOT(increaseDepth()));
+ connect(depthHandler->decreaseBtn, SIGNAL(clicked()), this, SLOT(decreaseDepth()));
+ depthHandler->setPos(fromPercent(0, Qt::Horizontal), fromPercent(85, Qt::Vertical));
+ depthHandler->setZValue(-2);
+ scene()->addItem(depthHandler);
+
+ minMinutes = TIME_INITIAL_MAX;
QAction *action = NULL;
#define ADD_ACTION( SHORTCUT, Slot ) \
@@ -888,7 +895,7 @@ void Ruler::setColor(const QColor& color)
setPen(defaultPen);
}
-Button::Button(QObject* parent): QObject(parent), QGraphicsRectItem()
+Button::Button(QObject* parent, QGraphicsItem *itemParent): QObject(parent), QGraphicsRectItem(itemParent)
{
icon = new QGraphicsPixmapItem(this);
text = new QGraphicsSimpleTextItem(this);
@@ -900,7 +907,7 @@ Button::Button(QObject* parent): QObject(parent), QGraphicsRectItem()
void Button::setPixmap(const QPixmap& pixmap)
{
- icon->setPixmap(pixmap.scaled(20,20, Qt::KeepAspectRatio, Qt::SmoothTransformation));
+ icon->setPixmap(pixmap);
if(pixmap.isNull())
icon->hide();
else
@@ -1455,3 +1462,46 @@ void DivePlannerPointsModel::createPlan()
CylindersModel::instance()->setDive(current_dive);
CylindersModel::instance()->update();
}
+
+ExpanderGraphics::ExpanderGraphics(QGraphicsItem* parent): QGraphicsRectItem(parent)
+{
+ icon = new QGraphicsPixmapItem(this);
+ bg = new QGraphicsPixmapItem(this);
+ leftWing = new QGraphicsPixmapItem(this);
+ rightWing = new QGraphicsPixmapItem(this);
+
+ QPixmap p;
+ #define CREATE(item, pixmap) \
+ p = QPixmap(QString( pixmap ));\
+ item->setPixmap(p); \
+
+ CREATE(icon, ":icon_time");
+ CREATE(bg, ":round_base");
+ CREATE(leftWing, ":left_wing");
+ CREATE(rightWing, ":right_wing");
+ #undef CREATE
+
+ decreaseBtn = new Button(0, this);
+ increaseBtn = new Button(0, this);
+ decreaseBtn->setPixmap(QPixmap(":arrow_down"));
+ increaseBtn->setPixmap(QPixmap(":arrow_up"));
+
+ icon->setFlag(ItemIgnoresTransformations);
+ bg->setFlag(ItemIgnoresTransformations);
+ leftWing->setFlag(ItemIgnoresTransformations);
+ rightWing->setFlag(ItemIgnoresTransformations);
+ decreaseBtn->setFlag(ItemIgnoresTransformations);
+ increaseBtn->setFlag(ItemIgnoresTransformations);
+ setFlag(ItemIgnoresTransformations);
+ leftWing->setZValue(-2);
+ rightWing->setZValue(-2);
+ bg->setZValue(-1);
+
+ leftWing->setPos(0,0);
+ bg->setPos(leftWing->pos().x() + leftWing->boundingRect().width() -60, 5);
+ rightWing->setPos(leftWing->pos().x() + leftWing->boundingRect().width() - 20, 0);
+ decreaseBtn->setPos(leftWing->pos().x(), leftWing->pos().y() );
+ increaseBtn->setPos(rightWing->pos().x(), rightWing->pos().y() );
+ icon->setPos(bg->pos().x(), bg->pos().y() - 5);
+ setTransformOriginPoint(transformOriginPoint().x(), transformOriginPoint().y() - childrenBoundingRect().height());
+}
diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h
index bd9b254d1..a310cf045 100644
--- a/qt-ui/diveplanner.h
+++ b/qt-ui/diveplanner.h
@@ -82,10 +82,9 @@ private:
class Button : public QObject, public QGraphicsRectItem {
Q_OBJECT
public:
- explicit Button(QObject* parent = 0);
+ Button(QObject* parent = 0, QGraphicsItem *itemParent = 0);
void setText(const QString& text);
void setPixmap(const QPixmap& pixmap);
-
protected:
virtual void mousePressEvent(QGraphicsSceneMouseEvent* event);
signals:
@@ -95,6 +94,20 @@ private:
QGraphicsSimpleTextItem *text;
};
+
+class ExpanderGraphics : public QGraphicsRectItem {
+public:
+ ExpanderGraphics(QGraphicsItem *parent = 0);
+
+ QGraphicsPixmapItem *icon;
+ Button *increaseBtn;
+ Button *decreaseBtn;
+private:
+ QGraphicsPixmapItem *bg;
+ QGraphicsPixmapItem *leftWing;
+ QGraphicsPixmapItem *rightWing;
+};
+
class DiveHandler : public QObject, public QGraphicsEllipseItem{
Q_OBJECT
public:
@@ -206,10 +219,8 @@ private:
QGraphicsSimpleTextItem *depthString;
/* Buttons */
- Button *plusTime; // adds 10 minutes to the time ruler.
- Button *plusDepth; // adds 10 meters to the depth ruler.
- Button *lessTime; // remove 10 minutes to the time ruler.
- Button *lessDepth; // remove 10 meters to the depth ruler.
+ ExpanderGraphics *depthHandler;
+ ExpanderGraphics *timeHandler;
int minMinutes; // this holds the minimum duration of the dive.
int dpMaxTime; // this is the time of the dive calculated by the deco.