summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/diveplanner.cpp62
-rw-r--r--qt-ui/diveplanner.h13
2 files changed, 71 insertions, 4 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index e8cca8280..a8f45d91f 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -3,7 +3,12 @@
#include <cmath>
#include <QMouseEvent>
#include <QDebug>
+#include <QGraphicsWidget>
+#include <QGraphicsProxyWidget>
+#include <QPushButton>
+
#include "ui_diveplanner.h"
+#include "mainwindow.h"
#define TIME_INITIAL_MAX 30
@@ -49,14 +54,39 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
scene()->addItem(depthString);
plusDepth = new Button();
+ plusDepth->setPixmap(QPixmap(":plus"));
plusDepth->setPos(15, 1);
scene()->addItem(plusDepth);
connect(plusDepth, SIGNAL(clicked()), this, SLOT(increaseDepth()));
plusTime = new Button();
+ plusTime->setPixmap(QPixmap(":plus"));
plusTime->setPos(95, 90);
scene()->addItem(plusTime);
connect(plusTime, SIGNAL(clicked()), this, SLOT(increaseTime()));
+
+ okBtn = new Button();
+ okBtn->setText(tr("Ok"));
+ okBtn->setPos(1, 95);
+ scene()->addItem(okBtn);
+ connect(okBtn, SIGNAL(clicked()), this, SLOT(okClicked()));
+
+ cancelBtn = new Button();
+ cancelBtn->setText(tr("Cancel"));
+ cancelBtn->setPos(10,95);
+ scene()->addItem(cancelBtn);
+ connect(cancelBtn, SIGNAL(clicked()), this, SLOT(cancelClicked()));
+}
+
+void DivePlannerGraphics::cancelClicked()
+{
+ qDebug() << "clicked";
+ mainWindow()->showProfile();
+}
+
+void DivePlannerGraphics::okClicked()
+{
+ // todo.
}
void DivePlannerGraphics::increaseDepth()
@@ -359,10 +389,38 @@ double Ruler::minimum() const
return min;
}
-Button::Button(QObject* parent): QObject(parent), QGraphicsPixmapItem()
+Button::Button(QObject* parent): QObject(parent), QGraphicsRectItem()
{
- setPixmap(QPixmap(":plus").scaled(20,20));
+ icon = new QGraphicsPixmapItem(this);
+ text = new QGraphicsSimpleTextItem(this);
+ icon->setPos(0,0);
+ text->setPos(0,0);
setFlag(ItemIgnoresTransformations);
+ setPen(QPen(QBrush(Qt::white), 0));
+}
+
+void Button::setPixmap(const QPixmap& pixmap)
+{
+ icon->setPixmap(pixmap.scaled(20,20));
+ if(pixmap.isNull()){
+ icon->hide();
+ }else{
+ icon->show();
+ }
+ setRect(childrenBoundingRect());
+}
+
+void Button::setText(const QString& t)
+{
+ text->setText(t);
+ if(icon->pixmap().isNull()){
+ icon->hide();
+ text->setPos(0,0);
+ }else{
+ icon->show();
+ text->setPos(22,0);
+ }
+ setRect(childrenBoundingRect());
}
void Button::mousePressEvent(QGraphicsSceneMouseEvent* event)
diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h
index 4029a6875..f2073515d 100644
--- a/qt-ui/diveplanner.h
+++ b/qt-ui/diveplanner.h
@@ -5,14 +5,20 @@
#include <QGraphicsPathItem>
#include <QDialog>
-class Button : public QObject, public QGraphicsPixmapItem {
+class Button : public QObject, public QGraphicsRectItem {
Q_OBJECT
public:
explicit Button(QObject* parent = 0);
+ void setText(const QString& text);
+ void setPixmap(const QPixmap& pixmap);
+
protected:
virtual void mousePressEvent(QGraphicsSceneMouseEvent* event);
signals:
void clicked();
+private:
+ QGraphicsPixmapItem *icon;
+ QGraphicsSimpleTextItem *text;
};
class DiveHandler : public QGraphicsEllipseItem{
@@ -66,6 +72,8 @@ protected:
private slots:
void increaseTime();
void increaseDepth();
+ void okClicked();
+ void cancelClicked();
private:
@@ -86,7 +94,8 @@ private:
Button *plusDepth;
Button *lessTime;
Button *lessDepth;
-
+ Button *okBtn;
+ Button *cancelBtn;
QPointF lastValidPos;
};