From 7e8c0d4aead5782a790284a8c9324d995c2b4c86 Mon Sep 17 00:00:00 2001 From: Laurent Redor Date: Thu, 25 Apr 2024 18:11:37 +0200 Subject: [PATCH] [63] Use precise coordinates in DragEditPartsTrackerEx.snapPoint Bug: https://github.com/eclipse-gmf-runtime/gmf-runtime/issues/63 --- .../ui/tools/DragEditPartsTrackerEx.java | 29 +++++++++++++------ 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/bundles/org.eclipse.gmf.runtime.diagram.ui/src/org/eclipse/gmf/runtime/diagram/ui/tools/DragEditPartsTrackerEx.java b/bundles/org.eclipse.gmf.runtime.diagram.ui/src/org/eclipse/gmf/runtime/diagram/ui/tools/DragEditPartsTrackerEx.java index 51f6822d7..c81ceee59 100644 --- a/bundles/org.eclipse.gmf.runtime.diagram.ui/src/org/eclipse/gmf/runtime/diagram/ui/tools/DragEditPartsTrackerEx.java +++ b/bundles/org.eclipse.gmf.runtime.diagram.ui/src/org/eclipse/gmf/runtime/diagram/ui/tools/DragEditPartsTrackerEx.java @@ -1,5 +1,5 @@ /****************************************************************************** - * Copyright (c) 2002, 2008 IBM Corporation and others. + * Copyright (c) 2002, 2024 IBM Corporation and others. * This program and the accompanying materials are made * available under the terms of the Eclipse Public License 2.0 * which is available at https://www.eclipse.org/legal/epl-2.0/ @@ -56,7 +56,8 @@ public DragEditPartsTrackerEx(EditPart sourceEditPart) { /** * @see org.eclipse.gef.tools.AbstractTool#getCommand() */ - protected Command getCommand() { + @Override + protected Command getCommand() { if (!isMove()) { CompoundCommand command = new CompoundCommand(); addSourceCommands(false, command); @@ -116,7 +117,8 @@ protected void addSourceCommands(boolean isMove, CompoundCommand command) { /** * @see org.eclipse.gef.tools.AbstractTool#getCommandName() */ - protected String getCommandName() { + @Override + protected String getCommandName() { if (!isMove()) return RequestConstants.REQ_DROP; return super.getCommandName(); @@ -126,7 +128,8 @@ protected String getCommandName() { * If the source is not in the operation set, it is not a move * @see org.eclipse.gef.tool s.DragEditPartsTracker#isMove() */ - protected boolean isMove() { + @Override + protected boolean isMove() { for (int i = 0 ; i < getOperationSet().size(); i++){ if (getOperationSet().get(i).equals(getSourceEditPart())){ return super.isMove(); @@ -148,7 +151,8 @@ protected boolean isMove() { /* (non-Javadoc) * @see org.eclipse.gef.tools.AbstractTool#executeCurrentCommand() */ - protected void executeCurrentCommand() { + @Override + protected void executeCurrentCommand() { super.executeCurrentCommand(); if (isActive()) { if (getOperationSet().size() > 0) { @@ -174,6 +178,7 @@ protected void reveal(EditPart editpart){ editpart.getViewer().reveal(editpart); } + @Override protected boolean handleDragInProgress() { boolean returnValue = super.handleDragInProgress(); if (isInState(STATE_DRAG_IN_PROGRESS) @@ -186,6 +191,7 @@ protected boolean handleDragInProgress() { return returnValue; } + @Override protected Cursor calculateCursor() { if (isInState(STATE_DRAG_IN_PROGRESS) || isInState(STATE_ACCESSIBLE_DRAG_IN_PROGRESS)) { @@ -215,6 +221,7 @@ protected Cursor calculateCursor() { return super.calculateCursor(); } + @Override protected boolean handleButtonDown(int button) { // If the group is selected, and the user clicks on a shape, defer the @@ -232,6 +239,7 @@ && getSourceEditPart().getParent().getSelected() != EditPart.SELECTED_NONE) { return super.handleButtonDown(button); } + @Override protected boolean handleDoubleClick(int button) { // If the user double-clicks a shape in a group and the shape is not // selected, select the shape. @@ -244,6 +252,7 @@ && getSourceEditPart().getSelected() == EditPart.SELECTED_NONE) { } } + @Override protected void performSelection() { super.performSelection(); @@ -258,23 +267,24 @@ && getSourceEditPart().getParent().getSelected() != EditPart.SELECTED_NONE) { * Overridden to add extended data to the request to restrict snapping to * specific directions based on the move delta. */ + @Override protected void snapPoint(ChangeBoundsRequest request) { Point moveDelta = request.getMoveDelta(); if (getState() == STATE_ACCESSIBLE_DRAG_IN_PROGRESS) { int restrictedDirection = 0; - if (moveDelta.x > 0) { + if (moveDelta.preciseX() > 0) { restrictedDirection = restrictedDirection | PositionConstants.EAST; - } else if (moveDelta.x < 0) { + } else if (moveDelta.preciseX() < 0) { restrictedDirection = restrictedDirection | PositionConstants.WEST; } - if (moveDelta.y > 0) { + if (moveDelta.preciseY() > 0) { restrictedDirection = restrictedDirection | PositionConstants.SOUTH; - } else if (moveDelta.y < 0) { + } else if (moveDelta.preciseY() < 0) { restrictedDirection = restrictedDirection | PositionConstants.NORTH; } @@ -286,6 +296,7 @@ protected void snapPoint(ChangeBoundsRequest request) { super.snapPoint(request); } + @Override protected boolean handleKeyDown(KeyEvent e) { if (acceptArrowKey(e)) { if (isInState(STATE_INITIAL)) {