/* Violet - A program for editing UML diagrams. Copyright (C) 2002 Cay S. Horstmann (http://horstmann.com) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package com.horstmann.violet; import java.awt.geom.Point2D; import java.awt.geom.Rectangle2D; import java.util.ArrayList; import com.horstmann.violet.framework.Direction; import com.horstmann.violet.framework.Node; import com.horstmann.violet.framework.SegmentedLineEdge; /** An edge that joins two call nodes. */ public class CallEdge extends SegmentedLineEdge { public CallEdge() { setSignal(false); } /** Gets the signal property. @return true if this is a signal edge */ public boolean isSignal() { return signal; } /** Sets the signal property. @param newValue true if this is a signal edge */ public void setSignal(boolean newValue) { signal = newValue; if (signal) setEndArrowHead(ArrowHead.HALF_V); else setEndArrowHead(ArrowHead.V); } public ArrayList getPoints() { ArrayList a = new ArrayList(); Node n = getEnd(); Rectangle2D start = getStart().getBounds(); Rectangle2D end = n.getBounds(); if (n instanceof CallNode && ((CallNode)n).getImplicitParameter() == ((CallNode)getStart()).getImplicitParameter()) { Point2D p = new Point2D.Double(start.getMaxX(), end.getY() - CallNode.CALL_YGAP / 2); Point2D q = new Point2D.Double(end.getMaxX(), end.getY()); Point2D s = new Point2D.Double(q.getX() + end.getWidth(), q.getY()); Point2D r = new Point2D.Double(s.getX(), p.getY()); a.add(p); a.add(r); a.add(s); a.add(q); } else if (n instanceof PointNode) // show nicely in tool bar { a.add(new Point2D.Double(start.getMaxX(), start.getY())); a.add(new Point2D.Double(end.getX(), start.getY())); } else { Direction d = new Direction(start.getX() - end.getX(), 0); Point2D endPoint = getEnd().getConnectionPoint(d); if (start.getCenterX() < endPoint.getX()) a.add(new Point2D.Double(start.getMaxX(), endPoint.getY())); else a.add(new Point2D.Double(start.getX(), endPoint.getY())); a.add(endPoint); } return a; } private boolean signal; }