summaryrefslogtreecommitdiff
path: root/src/plugins/qmldesigner/components/formeditor/movetool.cpp
diff options
context:
space:
mode:
authorThomas Hartmann <Thomas.Hartmann@nokia.com>2011-06-27 15:52:14 +0200
committerMarco Bubke <marco.bubke@nokia.com>2011-06-27 16:22:02 +0200
commitd7ed0667e95690b9c1382534518940d03b179cf0 (patch)
tree381597f9029bc2904c6a86ea3e346fcd68a6cb09 /src/plugins/qmldesigner/components/formeditor/movetool.cpp
parenta9f53ec9c5629cd2a9914fa6b8d7cba7612f4bbb (diff)
downloadqt-creator-d7ed0667e95690b9c1382534518940d03b179cf0.tar.gz
QmlDesigner.formeEditor: add handler for context menu
This patch adds a handler for a context menu to AbstactFormEditorTool. Also all the tools are patched to ignore right mouse keys for now. The ResizeManipulator gets an active property. Change-Id: I66b247ce6ae8e9f88517a1c1698432fb64f70da7 Reviewed-on: http://codereview.qt.nokia.com/770 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: Marco Bubke <marco.bubke@nokia.com>
Diffstat (limited to 'src/plugins/qmldesigner/components/formeditor/movetool.cpp')
-rw-r--r--src/plugins/qmldesigner/components/formeditor/movetool.cpp100
1 files changed, 55 insertions, 45 deletions
diff --git a/src/plugins/qmldesigner/components/formeditor/movetool.cpp b/src/plugins/qmldesigner/components/formeditor/movetool.cpp
index fbbd119eef..f72994d646 100644
--- a/src/plugins/qmldesigner/components/formeditor/movetool.cpp
+++ b/src/plugins/qmldesigner/components/formeditor/movetool.cpp
@@ -74,46 +74,52 @@ void MoveTool::clear()
void MoveTool::mousePressEvent(const QList<QGraphicsItem*> &itemList,
QGraphicsSceneMouseEvent *event)
{
- if (itemList.isEmpty())
- return;
- m_movingItems = movingItems(items());
- if (m_movingItems.isEmpty())
- return;
+ if (event->button() == Qt::LeftButton) {
+ if (itemList.isEmpty())
+ return;
+ m_movingItems = movingItems(items());
+ if (m_movingItems.isEmpty())
+ return;
- m_moveManipulator.setItems(m_movingItems);
- m_moveManipulator.begin(event->scenePos());
+ m_moveManipulator.setItems(m_movingItems);
+ m_moveManipulator.begin(event->scenePos());
+ }
+
+ AbstractFormEditorTool::mousePressEvent(itemList, event);
}
void MoveTool::mouseMoveEvent(const QList<QGraphicsItem*> &itemList,
QGraphicsSceneMouseEvent *event)
{
- if (m_movingItems.isEmpty())
- return;
+ if (m_moveManipulator.isActive()) {
+ if (m_movingItems.isEmpty())
+ return;
-// m_selectionIndicator.hide();
- m_resizeIndicator.hide();
+ // m_selectionIndicator.hide();
+ m_resizeIndicator.hide();
- FormEditorItem *containerItem = containerFormEditorItem(itemList, m_movingItems);
- if (containerItem
- && view()->currentState().isBaseState()) {
- if (containerItem != m_movingItems.first()->parentItem()
- && event->modifiers().testFlag(Qt::ShiftModifier)) {
- m_moveManipulator.reparentTo(containerItem);
+ FormEditorItem *containerItem = containerFormEditorItem(itemList, m_movingItems);
+ if (containerItem
+ && view()->currentState().isBaseState()) {
+ if (containerItem != m_movingItems.first()->parentItem()
+ && event->modifiers().testFlag(Qt::ShiftModifier)) {
+ m_moveManipulator.reparentTo(containerItem);
+ }
}
- }
- bool shouldSnapping = view()->widget()->snappingAction()->isChecked();
- bool shouldSnappingAndAnchoring = view()->widget()->snappingAndAnchoringAction()->isChecked();
+ bool shouldSnapping = view()->widget()->snappingAction()->isChecked();
+ bool shouldSnappingAndAnchoring = view()->widget()->snappingAndAnchoringAction()->isChecked();
- MoveManipulator::Snapping useSnapping = MoveManipulator::NoSnapping;
- if (event->modifiers().testFlag(Qt::ControlModifier) != (shouldSnapping || shouldSnappingAndAnchoring)) {
- if (shouldSnappingAndAnchoring)
- useSnapping = MoveManipulator::UseSnappingAndAnchoring;
- else
- useSnapping = MoveManipulator::UseSnapping;
- }
+ MoveManipulator::Snapping useSnapping = MoveManipulator::NoSnapping;
+ if (event->modifiers().testFlag(Qt::ControlModifier) != (shouldSnapping || shouldSnappingAndAnchoring)) {
+ if (shouldSnappingAndAnchoring)
+ useSnapping = MoveManipulator::UseSnappingAndAnchoring;
+ else
+ useSnapping = MoveManipulator::UseSnapping;
+ }
- m_moveManipulator.update(event->scenePos(), useSnapping);
+ m_moveManipulator.update(event->scenePos(), useSnapping);
+ }
}
void MoveTool::hoverMoveEvent(const QList<QGraphicsItem*> &itemList,
@@ -195,31 +201,35 @@ void MoveTool::keyReleaseEvent(QKeyEvent *keyEvent)
}
}
-void MoveTool::mouseReleaseEvent(const QList<QGraphicsItem*> &/*itemList*/,
+void MoveTool::mouseReleaseEvent(const QList<QGraphicsItem*> &itemList,
QGraphicsSceneMouseEvent *event)
{
- if (m_movingItems.isEmpty())
- return;
+ if (m_moveManipulator.isActive()) {
+ if (m_movingItems.isEmpty())
+ return;
- QLineF moveVector(event->scenePos(), m_moveManipulator.beginPoint());
- if (moveVector.length() < QApplication::startDragDistance())
- {
- QPointF beginPoint(m_moveManipulator.beginPoint());
+ QLineF moveVector(event->scenePos(), m_moveManipulator.beginPoint());
+ if (moveVector.length() < QApplication::startDragDistance())
+ {
+ QPointF beginPoint(m_moveManipulator.beginPoint());
- m_moveManipulator.end(beginPoint);
+ m_moveManipulator.end(beginPoint);
-// m_selectionIndicator.show();
- m_resizeIndicator.show();
- m_movingItems.clear();
+ // m_selectionIndicator.show();
+ m_resizeIndicator.show();
+ m_movingItems.clear();
- view()->changeToSelectionTool(event);
- } else {
- m_moveManipulator.end(event->scenePos());
+ view()->changeToSelectionTool(event);
+ } else {
+ m_moveManipulator.end(event->scenePos());
- m_selectionIndicator.show();
- m_resizeIndicator.show();
- m_movingItems.clear();
+ m_selectionIndicator.show();
+ m_resizeIndicator.show();
+ m_movingItems.clear();
+ }
}
+
+ AbstractFormEditorTool::mouseReleaseEvent(itemList, event);
}
void MoveTool::mouseDoubleClickEvent(const QList<QGraphicsItem*> &itemList, QGraphicsSceneMouseEvent *event)