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

org.geotools.styling.GraphicImpl Maven / Gradle / Ivy

Go to download

The main module contains the GeoTools public interfaces that are used by other GeoTools modules (and GeoTools applications). Where possible we make use industry standard terms as provided by OGC and ISO standards. The formal GeoTools public api consists of gt-metadata, jts and the gt-main module. The main module contains the default implementations that are available provided to other GeoTools modules using our factory system. Factories are obtained from an appropriate FactoryFinder, giving applications a chance configure the factory used using the Factory Hints facilities. FilterFactory ff = CommonFactoryFinder.getFilterFactory(); Expression expr = ff.add( expression1, expression2 ); If you find yourself using implementation specific classes chances are you doing it wrong: Expression expr = new AddImpl( expression1, expressiom2 );

There is a newer version: 24.2-oss84-1
Show newest version
/*
 *    GeoTools - The Open Source Java GIS Toolkit
 *    http://geotools.org
 *
 *    (C) 2002-2008, Open Source Geospatial Foundation (OSGeo)
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation;
 *    version 2.1 of the License.
 *
 *    This library is distributed in the hope that it will be useful,
 *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *    Lesser General Public License for more details.
 */
package org.geotools.styling;

import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import org.geotools.factory.CommonFactoryFinder;
import org.geotools.filter.ConstantExpression;
import org.geotools.util.Utilities;
import org.geotools.util.factory.GeoTools;
import org.opengis.filter.FilterFactory;
import org.opengis.filter.expression.Expression;
import org.opengis.style.AnchorPoint;
import org.opengis.style.GraphicalSymbol;
import org.opengis.style.StyleVisitor;
import org.opengis.util.Cloneable;

/**
 * Direct implementation of Graphic.
 *
 * @author Ian Turton, CCG
 * @author Johann Sorel (Geomatys)
 * @version $Id$
 */
public class GraphicImpl implements Graphic, Cloneable {
    /** The logger for the default core module. */
    // private static final java.util.logging.Logger LOGGER =
    // org.geotools.util.logging.Logging.getLogger(GraphicImpl.class);

    private final List graphics = new ArrayList();

    private AnchorPointImpl anchor;
    private Expression gap;
    private Expression initialGap;

    private Expression rotation = null;
    private Expression size = null;
    private DisplacementImpl displacement = null;
    private Expression opacity = null;

    /** Creates a new instance of DefaultGraphic */
    protected GraphicImpl() {
        this(CommonFactoryFinder.getFilterFactory(GeoTools.getDefaultHints()));
    }

    public GraphicImpl(FilterFactory factory) {
        this(factory, null, null, null);
    }

    public GraphicImpl(
            FilterFactory factory, AnchorPoint anchor, Expression gap, Expression initialGap) {
        this.anchor = AnchorPointImpl.cast(anchor);

        if (gap == null) this.gap = ConstantExpression.constant(0);
        else this.gap = gap;
        if (initialGap == null) this.initialGap = ConstantExpression.constant(0);
        else this.initialGap = initialGap;
    }

    public List graphicalSymbols() {
        return graphics;
    }

    public AnchorPointImpl getAnchorPoint() {
        return anchor;
    }

    public void setAnchorPoint(org.geotools.styling.AnchorPoint anchor) {
        this.anchor = AnchorPointImpl.cast(anchor);
    }

    public void setAnchorPoint(org.opengis.style.AnchorPoint anchorPoint) {
        this.anchor = AnchorPointImpl.cast(anchorPoint);
    }

    /**
     * This specifies the level of translucency to use when rendering the graphic.
* The value is encoded as a floating-point value between 0.0 and 1.0 with 0.0 representing * totally transparent and 1.0 representing totally opaque, with a linear scale of translucency * for intermediate values.
* For example, "0.65" would represent 65% opacity. The default value is 1.0 (opaque). * * @return The opacity of the Graphic, where 0.0 is completely transparent and 1.0 is completely * opaque. */ public Expression getOpacity() { return opacity; } /** * This parameter defines the rotation of a graphic in the clockwise direction about its centre * point in decimal degrees. The value encoded as a floating point number. * * @return The angle of rotation in decimal degrees. Negative values represent counter-clockwise * rotation. The default is 0.0 (no rotation). */ public Expression getRotation() { return rotation; } /** * This paramteter gives the absolute size of the graphic in pixels encoded as a floating point * number. * *

The default size of an image format (such as GIFD) is the inherent size of the image. The * default size of a format without an inherent size (such as SVG) is defined to be 16 pixels in * height and the corresponding aspect in width. If a size is specified, the height of the * graphic will be scaled to that size and the corresponding aspect will be used for the width. * * @return The size of the graphic, the default is context specific. Negative values are not * possible. */ public Expression getSize() { return size; } public DisplacementImpl getDisplacement() { return displacement; } public Expression getInitialGap() { return initialGap; } public void setInitialGap(Expression initialGap) { this.initialGap = initialGap; } public Expression getGap() { return gap; } public void setGap(Expression gap) { this.gap = gap; } public void setDisplacement(org.opengis.style.Displacement offset) { this.displacement = DisplacementImpl.cast(offset); } public void setOpacity(Expression opacity) { this.opacity = opacity; } /** * Setter for property rotation. * * @param rotation New value of property rotation. */ public void setRotation(Expression rotation) { this.rotation = rotation; } /** * Setter for property size. * * @param size New value of property size. */ public void setSize(Expression size) { this.size = size; } public Object accept(StyleVisitor visitor, Object data) { return visitor.visit((org.opengis.style.GraphicStroke) this, data); } public void accept(org.geotools.styling.StyleVisitor visitor) { visitor.visit(this); } /** * Creates a deep copy clone. * * @return The deep copy clone. */ public Object clone() { GraphicImpl clone; try { clone = (GraphicImpl) super.clone(); clone.graphics.clear(); clone.graphics.addAll(graphics); } catch (CloneNotSupportedException e) { throw new RuntimeException(e); // this should never happen. } return clone; } /** * Override of hashcode * * @return The hashcode. */ public int hashCode() { final int PRIME = 1000003; int result = 0; if (graphics != null) { result = (PRIME * result) + graphics.hashCode(); } if (rotation != null) { result = (PRIME * result) + rotation.hashCode(); } if (size != null) { result = (PRIME * result) + size.hashCode(); } if (opacity != null) { result = (PRIME * result) + opacity.hashCode(); } // if (gap != null) { // result = (PRIME * result) + gap.hashCode(); // } // // if (initialGap != null) { // result = (PRIME * result) + initialGap.hashCode(); // } return result; } /** * Compares this GraphicImpl with another for equality. * *

Two graphics are equal if and only if they both have the same geometry property name and * the same list of symbols and the same rotation, size and opacity. * * @param oth The other GraphicsImpl to compare with. * @return True if this is equal to oth according to the above conditions. */ public boolean equals(Object oth) { if (this == oth) { return true; } if (oth instanceof GraphicImpl) { GraphicImpl other = (GraphicImpl) oth; return Utilities.equals(this.size, other.size) && Utilities.equals(this.rotation, other.rotation) && Utilities.equals(this.opacity, other.opacity) && Objects.equals(this.graphicalSymbols(), other.graphicalSymbols()); } return false; } static GraphicImpl cast(org.opengis.style.Graphic graphic) { if (graphic == null) { return null; } else if (graphic instanceof GraphicImpl) { return (GraphicImpl) graphic; } else { GraphicImpl copy = new GraphicImpl(); copy.setAnchorPoint(graphic.getAnchorPoint()); copy.setDisplacement(graphic.getDisplacement()); if (graphic.graphicalSymbols() != null) { for (GraphicalSymbol item : graphic.graphicalSymbols()) { if (item instanceof org.opengis.style.ExternalGraphic) { copy.graphicalSymbols().add(ExternalGraphicImpl.cast(item)); } else if (item instanceof org.opengis.style.Mark) { copy.graphicalSymbols().add(MarkImpl.cast(item)); } } } return copy; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy