//Copyright (c) 2006 - 2008, Markus Strauch.
//All rights reserved.
//
//Redistribution and use in source and binary forms, with or without
//modification, are permitted provided that the following conditions are met:
//
//* Redistributions of source code must retain the above copyright notice,
//this list of conditions and the following disclaimer.
//* Redistributions in binary form must reproduce the above copyright notice,
//this list of conditions and the following disclaimer in the documentation
//and/or other materials provided with the distribution.
//
//THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
//AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
//IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
//ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
//LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
//CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
//SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
//INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
//CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
//ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
//THE POSSIBILITY OF SUCH DAMAGE.
package net.sf.sdedit.message;
import net.sf.sdedit.diagram.Diagram;
import net.sf.sdedit.diagram.Lifeline;
import net.sf.sdedit.diagram.MessageData;
import net.sf.sdedit.drawable.Arrow;
import net.sf.sdedit.drawable.ArrowStroke;
import net.sf.sdedit.util.Direction;
/**
* A specialized forward message, representing a call to a constructor.
* <tt>ConstructorMessage</tt> objects are responsible for making the head of
* the newly created object appear on the diagram.
*
* @author Markus Strauch
*
*/
public class ConstructorMessage extends ForwardMessage
{
/**
* Creates a new constructor message.
*
* @param caller
* the lifeline that calls the constructor
* @param callee
* the yet hidden lifeline corresponding to the object newly
* created
* @param diagram
* the diagram where to draw
* @param data
* encapsulates the data of the constructor message
*/
public ConstructorMessage(Lifeline caller, Lifeline callee,
Diagram diagram, MessageData data) {
super(caller, callee, diagram, data);
}
public void updateView() {
int headHeight = getCallee().getHead().getHeight();
getDiagram().getPaintDevice().announce(getConfiguration().getSpaceBeforeConstruction()
+ Math.max(0,Arrow.getInnerHeight(this) - headHeight / 2)
+ headHeight + getDiagram().getConfiguration().getInitialSpace());
extendLifelines(getConfiguration().getSpaceBeforeConstruction());
int s = 0;
Arrow arrow;
if (getCaller().getPosition() < getCallee().getPosition()) {
arrow = new Arrow(this, ArrowStroke.SOLID, Direction.RIGHT, v());
} else {
arrow = new Arrow(this, ArrowStroke.SOLID, Direction.LEFT, v());
s=3;
}
setArrow(arrow);
arrow.setSpace(s+getCallee().getHead().getWidth() / 2);
//- getConfiguration().getMainLifelineWidth() / 2);
getDiagram().getPaintDevice().addSequenceElement(arrow);
int diff = arrow.getInnerHeight() - headHeight/2;
if (diff > 0) {
extendLifelines(diff);
}
getCallee().getHead().setTop(v());
extendLifelines(headHeight/2);
getCallee().giveBirth();
getCallee().getView().setTop(v());
getCallee().getView().setHeight(0);
extendLifelines(headHeight/2 + getDiagram().getConfiguration().getInitialSpace());
if (isActivating()) {
getCallee().setActive(true);
}
}
}