blob: 7b20fd38b2cad4949a170401a671666b8cbe6035 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
/*****************************************************************************
* Copyright (c) 2016 CEA LIST and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* CEA LIST - Initial API and implementation
* Nicolas FAUVERGUE (CEA LIST) nicolas.fauvergue@cea.fr - Bug 531596
*
*****************************************************************************/
package org.eclipse.papyrus.uml.diagram.sequence;
import org.eclipse.draw2d.ConnectionAnchor;
import org.eclipse.draw2d.geometry.Dimension;
import org.eclipse.draw2d.geometry.Point;
import org.eclipse.draw2d.geometry.PointList;
import org.eclipse.draw2d.geometry.PrecisionPoint;
import org.eclipse.draw2d.geometry.Rectangle;
import org.eclipse.gmf.runtime.draw2d.ui.figures.BaseSlidableAnchor;
import org.eclipse.gmf.runtime.gef.ui.figures.NodeFigure;
import org.eclipse.gmf.runtime.notation.Bounds;
import org.eclipse.gmf.runtime.notation.Node;
import org.eclipse.papyrus.infra.gmfdiag.common.figure.node.LinkLFSVGNodePlateFigure;
import org.eclipse.papyrus.uml.diagram.sequence.referencialgrilling.BoundForEditPart;
/**
* This figure is used in order to allow a link to follow the shape of the lifeLine
* see getPolygonPoints()
*
* @since 3.0
*
*/
public class LifelineNodePlate extends LinkLFSVGNodePlateFigure {
/**
* Constructor.
*
* @param hostEP
* @param width
* @param height
* @param lifelineEditPart
* TODO
*/
public LifelineNodePlate(org.eclipse.gef.GraphicalEditPart hostEP, int width, int height) {
super(hostEP, width, height);
withLinkLFEnabled();
followSVGPapyrusPath = true;
}
/**
* @see org.eclipse.gmf.runtime.gef.ui.figures.NodeFigure#getPolygonPoints()
*/
@Override
public PointList getPolygonPoints() {
return ((NodeFigure) this.getChildren().get(0)).getPolygonPoints();
}
@Override
protected ConnectionAnchor createAnchor(PrecisionPoint p) {
p.setPreciseX(0.5);// a changer
return super.createAnchor(p);
}
/**
* {@inheritDoc}
*/
@Override
protected ConnectionAnchor createConnectionAnchor(Point p) {
if (p == null) {
return getConnectionAnchor(szAnchor);
} else {
Point temp = p.getCopy();
translateToRelative(temp);
// This allows to calculate the bounds corresponding to the node instead of the figure bounds
final Bounds bounds = BoundForEditPart.getBounds((Node) getGraphicalEditPart().getModel());
final Rectangle rectangle = new Rectangle(new Point(bounds.getX(), bounds.getY()), new Dimension(bounds.getWidth(), bounds.getHeight()));
PrecisionPoint pt = BaseSlidableAnchor.getAnchorRelativeLocation(temp, rectangle);
return createAnchor(pt);
}
}
/**
* @see org.eclipse.gmf.runtime.gef.ui.figures.NodeFigure#isDefaultAnchorArea(org.eclipse.draw2d.geometry.PrecisionPoint)
*/
@Override
protected boolean isDefaultAnchorArea(PrecisionPoint p) {
return false;
}
@Override
public boolean containsPoint(int x, int y) {
if (Math.abs(this.getBounds().x + this.getBounds().width / 2 - x) < 20) {
return super.containsPoint(x, y);
}
return false;
}
}
|