view flys-artifacts/src/main/java/de/intevation/flys/java2d/ShapeUtils.java @ 4837:9e25c7523485

Fixed calculation of effective width in MINFO SQ relation. * Get all (including empty datasets) from db. * Filter empty datasets when processing data of the same date. * Added debug outputs.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 23 Jan 2013 11:14:41 +0100
parents 0d8146989012
children
line wrap: on
line source
package de.intevation.flys.java2d;

import java.awt.Shape;

import java.awt.geom.AffineTransform;
import java.awt.geom.Ellipse2D;
import java.awt.geom.GeneralPath;
import java.awt.geom.Rectangle2D;

import java.util.HashMap;
import java.util.Map;

public class ShapeUtils
{
    // TODO: Use enum
    public static final int MEASURED     = 0;
    public static final int DIGITIZED    = 1;
    public static final int INTERPOLATED = 2;

    public static final boolean DIGITIZED_FILL    = false;
    public static final boolean MEASURED_FILL     = true;
    public static final boolean INTERPOLATED_FILL = false;

   public static final Shape DIGITIZED_SHAPE =
        createCross(4f);

    public static final Shape MEASURED_SHAPE =
        new Rectangle2D.Double(-2, -2, 4, 4);

    public static final Shape INTERPOLATED_SHAPE =
        new Ellipse2D.Double(-2, -2, 4, 4);

    protected static Map<Long, Shape> scaledShapesCache =
        new HashMap<Long, Shape>();

    public static final Shape createCross(float size) {
        float half = size * 0.5f;
        GeneralPath p = new GeneralPath();
        p.moveTo(-half, -half);
        p.lineTo(half, half);
        p.closePath();
        p.moveTo(-half, half);
        p.lineTo(half, -half);
        p.closePath();
        return p;
    }

    public static Shape scale(Shape shape, float factor) {
        if (factor == 1f) {
            return shape;
        }
        AffineTransform xform =
            AffineTransform.getScaleInstance(factor, factor);

        GeneralPath gp = new GeneralPath(shape);
        return gp.createTransformedShape(xform);
    }

    public static synchronized Shape getScaledShape(int type, float size) {

        Long hash = Long.valueOf(
            (((long)type) << 32) | Float.floatToIntBits(size));

        Shape shape = scaledShapesCache.get(hash);

        if (shape == null) {
            switch (type) {
                case MEASURED:
                    shape = MEASURED_SHAPE;
                    break;
                case DIGITIZED:
                    shape = DIGITIZED_SHAPE;
                    break;
                default:
                    shape = INTERPOLATED_SHAPE;
            }
            scaledShapesCache.put(hash, shape = scale(shape, size));
        }

        return shape;
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org