blob: 3666d3af1f72733caac86413ef07c17806fe864e [file] [log] [blame]
/*******************************************************************************
* <copyright>
*
* Copyright (c) 2005, 2010 SAP AG.
* 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:
* SAP AG - initial API, implementation and documentation
*
* </copyright>
*
*******************************************************************************/
package org.eclipse.graphiti.ui.internal.figures;
import org.eclipse.draw2d.Graphics;
import org.eclipse.draw2d.RotatableDecoration;
import org.eclipse.draw2d.geometry.Point;
import org.eclipse.draw2d.geometry.Rectangle;
import org.eclipse.graphiti.mm.algorithms.GraphicsAlgorithm;
import org.eclipse.graphiti.ui.internal.parts.IPictogramElementDelegate;
import org.eclipse.swt.graphics.Path;
/**
* A Graphiti Ellipse Rotatable Decoration. Most functionality is handled in the
* super-class. This class only has to define the path and the touch-point for
* the figure-specific painting.
*
* @noinstantiate This class is not intended to be instantiated by clients.
* @noextend This class is not intended to be subclassed by clients.
*/
public class GFEllipseDecoration extends GFAbstractRotatableDecoration implements RotatableDecoration {
/**
* The initial touch-point as described in {@link #getInitialTouchPoint()}.
*/
private Point initialTouchPoint = null;
/**
* Creates a new GFEllipseDecoration.
*
* @param pictogramElementDelegate
* The PictogramElementDelegate which provides the
* GraphicsAlgorithm.
* @param graphicsAlgorithm
* The GraphicsAlgorithm which provides the values to paint this
* Shape.
*/
public GFEllipseDecoration(IPictogramElementDelegate pictogramElementDelegate, GraphicsAlgorithm graphicsAlgorithm) {
super(pictogramElementDelegate, graphicsAlgorithm);
// shift the touchpoint by the x/y coordinates of the graphics algorithm
initialTouchPoint = new Point(0, getInitialBounds().height / 2);
initialTouchPoint.translate(-graphicsAlgorithm.getX(), -graphicsAlgorithm.getY());
}
// ============================= abstract methods =========================
/**
* Returns the initial touch-point of the decorator-shape. This is the point
* of the decorator-shape inside the initial-bounds (see
* {@link #getInitialBounds()}), which shall touch the decorated figure at
* the decorator-location (see {@link #getDecoratorLocation()}. It is called
* "inital" because it is the point before translation/rotation.
* <p>
* In caes of this Ellipse the point
* <code>(0, getInitialBounds().height / 2)</code> is returned.
*
* @return The initial touch-point of the decorator-shape.
*/
@Override
protected Point getInitialTouchPoint() {
return initialTouchPoint;
}
/**
* Returns true, if the given point is contained inside this ellipse. This
* implementation overwrites the super-implementation, which only checks if
* the point is in the rectangular bounds.
*
* @param x
* The x-coordinate of the point to check.
* @param y
* The y-coordinate of the point to check.
* @return true, if the given point is contained inside this ellipse.
*/
@Override
public boolean containsPointInInitialFigure(int x, int y) {
return Boolean.TRUE.equals(GFFigureUtil.containsPointInEllipse(getInitialBounds(), x, y));
}
/**
* Returns the Path specifying an ellipse for the given outer bounds. It
* does not differentiate between a fill Path and an outline Path.
*
* @param outerBounds
* The outer bounds which shall contain the Path. They are
* calculated from the bounds of this figure by
* {@link GFFigureUtil#getAdjustedRectangle(Rectangle, double, int)}
* . Note, that those outline-bounds are just a suggestion which
* works fine for many cases.
* @param graphics
* The Graphics on which the outline Path shall be painted. It
* can be used to react on Graphics specific values, like the
* zoom-level of the Graphics.
* @param isFill
* if true, the Path is used for filling the Shape, otherwise for
* outlining the Shape.
* @return The Path specifying an ellipse for the given outer bounds.
*/
@Override
protected Path createPath(Rectangle outerBounds, Graphics graphics, boolean isFill) {
Path path = new Path(null);
float x = outerBounds.x;
float y = outerBounds.y;
float height = outerBounds.height;
float width = outerBounds.width;
path.moveTo(x, y);
path.addArc(x, y, width, height, 0, 360);
return path;
}
}