summaryrefslogtreecommitdiffstats
path: root/qt-ui
diff options
context:
space:
mode:
Diffstat (limited to 'qt-ui')
-rw-r--r--qt-ui/diveplanner.cpp46
-rw-r--r--qt-ui/diveplanner.h13
2 files changed, 3 insertions, 56 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index d84e4aea9..89e744e31 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -174,14 +174,6 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
ADD_ACTION(Qt::Key_Right, keyRightAction());
#undef ADD_ACTION
- // Prepare the stuff for the gas-choices.
- gasListView = new QListView();
- gasListView->setWindowFlags(Qt::Popup);
- gasListView->setModel(GasSelectionModel::instance());
- gasListView->hide();
- gasListView->installEventFilter(this);
-
- connect(gasListView, SIGNAL(activated(QModelIndex)), this, SLOT(selectGas(QModelIndex)));
connect(plannerModel, SIGNAL(dataChanged(QModelIndex,QModelIndex)), this, SLOT(drawProfile()));
connect(plannerModel, SIGNAL(rowsInserted(const QModelIndex&,int,int)),
@@ -191,34 +183,16 @@ DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent)
setRenderHint(QPainter::Antialiasing);
}
-bool DivePlannerGraphics::eventFilter(QObject *object, QEvent* event)
-{
- if (object != gasListView)
- return false;
- if (event->type() == QEvent::KeyPress) {
- QKeyEvent *ke = static_cast<QKeyEvent *>(event);
- if (ke->key() == Qt::Key_Escape)
- gasListView->hide();
- }
- if (event->type() == QEvent::MouseButtonPress){
- QMouseEvent *me = static_cast<QMouseEvent *>(event);
- if (!gasListView->geometry().contains(me->pos()))
- gasListView->hide();
- }
- return false;
-}
-
void DivePlannerGraphics::pointInserted(const QModelIndex& parent, int start , int end)
{
DiveHandler *item = new DiveHandler ();
scene()->addItem(item);
handles << item;
- Button *gasChooseBtn = new Button();
+ QGraphicsSimpleTextItem *gasChooseBtn = new QGraphicsSimpleTextItem();
scene()->addItem(gasChooseBtn);
gasChooseBtn->setZValue(10);
- connect(gasChooseBtn, SIGNAL(clicked()), this, SLOT(prepareSelectGas()));
-
+ gasChooseBtn->setFlag(QGraphicsItem::ItemIgnoresTransformations);
gases << gasChooseBtn;
drawProfile();
}
@@ -490,22 +464,6 @@ QStringList& DivePlannerPointsModel::getGasList()
return list;
}
-void DivePlannerGraphics::prepareSelectGas()
-{
- currentGasChoice = static_cast<Button*>(sender());
- QPoint c = QCursor::pos();
- gasListView->setGeometry(c.x(), c.y(), 150, 100);
- gasListView->show();
-}
-
-void DivePlannerGraphics::selectGas(const QModelIndex& index)
-{
- QString gasSelected = gasListView->model()->data(index, Qt::DisplayRole).toString();
- int idx = gases.indexOf(currentGasChoice);
- plannerModel->setData(plannerModel->index(idx, DivePlannerPointsModel::GAS), gasSelected);
- gasListView->hide();
-}
-
void DivePlannerGraphics::drawProfile()
{
qDeleteAll(lines);
diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h
index 1d15fb766..dc050a04b 100644
--- a/qt-ui/diveplanner.h
+++ b/qt-ui/diveplanner.h
@@ -175,11 +175,8 @@ private slots:
void decreaseTime();
void decreaseDepth();;
void drawProfile();
- void prepareSelectGas();
- void selectGas(const QModelIndex& index);
void pointInserted(const QModelIndex&, int start, int end);
void pointsRemoved(const QModelIndex&, int start, int end);
- bool eventFilter(QObject *object, QEvent* event);
private:
void moveActiveHandler(const QPointF& MappedPos, const int pos);
@@ -188,15 +185,7 @@ private:
/* This is the user-entered handles. */
QList<DiveHandler *> handles;
-
- /* this is the user-entered gases.
- This must be a button, so the
- user cna click to choose a new gas.
- */
- QList<Button*> gases;
- QListView *gasListView;
- QStringListModel *gasChoices;
- Button *currentGasChoice;
+ QList<QGraphicsSimpleTextItem*> gases;
/* those are the lines that follows the mouse. */
QGraphicsLineItem *verticalLine;