
org.geomajas.graphics.client.shape.AnchoredCross Maven / Gradle / Ivy
/*
* This is part of Geomajas, a GIS framework, http://www.geomajas.org/.
*
* Copyright 2008-2013 Geosparc nv, http://www.geosparc.com/, Belgium.
*
* The program is available in open source according to the Apache
* License, Version 2.0. All contributions in this program are covered
* by the Geomajas Contributors License Agreement. For full licensing
* details, see LICENSE.txt in the project root.
*/
package org.geomajas.graphics.client.shape;
import java.util.ArrayList;
import java.util.List;
import org.geomajas.graphics.client.object.Cloneable;
import org.vaadin.gwtgraphics.client.shape.Path;
import org.vaadin.gwtgraphics.client.shape.path.LineTo;
import org.vaadin.gwtgraphics.client.shape.path.MoveTo;
import org.vaadin.gwtgraphics.client.shape.path.PathStep;
import org.vaadin.gwtgraphics.client.shape.path.ScaleHelper;
/**
* A non-scaling cross (diagonals of a square) that is anchored to its world space location on a specific pixel or
* anchor location (useful for location markers).
* Using own veriosn of the steps code from {@link Path} internally in this class.
*
* @author Jan Venstermans
*
*/
public class AnchoredCross extends Path implements Cloneable {
private int crossHeightPixels;
private List steps = new ArrayList();
/**
* Creates a cross (diagonals of a square) at the specified world location with a specified size and anchor point.
* E.g., if (anchorX,anchorY)=(0, 0), the center of the cross will be positioned at the world
* location.
*
* @param userX x-location in world coordinates of the cross intersection point
* @param userY y-location in world coordinates of the cross intersection point
* @param crossHeightPixels height of the in pixels
* @param anchorX x-location of the anchor point (cross-relative)
* @param anchorY
* y-location of the anchor point (cross-relative)
*/
public AnchoredCross(double userX, double userY, int crossHeightPixels) {
super(userX, userY);
this.crossHeightPixels = crossHeightPixels;
}
@Override
public Object cloneObject() {
return new AnchoredCross(getUserX(), getUserY(), crossHeightPixels);
}
protected void drawTransformed() {
if (crossHeightPixels > 0) {
int heigth = (int) (crossHeightPixels / getScaleX());
if (steps != null) {
steps.clear();
} else {
steps = new ArrayList();
}
steps.add(new MoveTo(false, getUserX(), getUserY()));
moveRelativelyTo(-heigth / 2, -heigth / 2);
lineRelativelyTo(heigth, heigth);
moveRelativelyTo(0, -heigth);
lineRelativelyTo(-heigth, heigth);
MoveTo moveTo = (MoveTo) steps.get(0);
steps.set(0, new MoveTo(moveTo.isRelativeCoords(), moveTo.getUserX() + getDeltaX(), moveTo.getUserY()
+ getDeltaY()));
// apply scale
ScaleHelper scaleHelper = new ScaleHelper(getScaleX(), getScaleY());
for (PathStep step : steps) {
step.scale(scaleHelper);
}
getImpl().drawPath(getElement(), steps);
}
}
public void moveRelativelyTo(int x, int y) {
steps.add(new MoveTo(true, x, y));
}
public void moveRelativelyTo(double x, double y) {
steps.add(new MoveTo(true, x, y));
}
public void lineRelativelyTo(int x, int y) {
steps.add(new LineTo(true, x, y));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy