All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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