/* * Geotoolkit - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2008 - 2009, Geomatys * * 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; either * version 2.1 of the License, or (at your option) any later version. * * 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.geotoolkit.swe.xml.v101; import java.net.URI; import java.util.ArrayList; import java.util.List; import java.util.Objects; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlType; import org.geotoolkit.swe.xml.Coordinate; import org.geotoolkit.swe.xml.Vector; import org.apache.sis.util.ComparisonMode; import org.geotoolkit.gml.xml.AbstractGeometry; import org.geotoolkit.gml.xml.v311.DirectPositionType; import org.geotoolkit.gml.xml.v311.PointType; /** * <p>Java class for VectorType complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="VectorType"> * <complexContent> * <extension base="{http://www.opengis.net/swe/1.0.1}AbstractVectorType"> * <sequence> * <element name="coordinate" maxOccurs="unbounded"> * <complexType> * <complexContent> * <restriction base="{http://www.w3.org/2001/XMLSchema}anyType"> * <group ref="{http://www.opengis.net/swe/1.0.1}AnyNumerical" minOccurs="0"/> * <attribute name="name" use="required" type="{http://www.w3.org/2001/XMLSchema}token" /> * </restriction> * </complexContent> * </complexType> * </element> * </sequence> * </extension> * </complexContent> * </complexType> * </pre> * * * @module */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "VectorType", propOrder = { "coordinate" }) public class VectorType extends AbstractVectorType implements Vector { @XmlElement(required = true) private List<CoordinateType> coordinate; public VectorType() { } public VectorType(final Vector v) { super(v); if (v != null && v.getCoordinate() != null) { this.coordinate = new ArrayList<>(); for (Coordinate c : v.getCoordinate()) { this.coordinate.add(new CoordinateType(c)); } } } public VectorType(final URI referenceFrame, final URI localFrame, final List<CoordinateType> coordinate) { super(referenceFrame, localFrame); this.coordinate = coordinate; } public VectorType(final String definition, final List<CoordinateType> coordinate) { super(definition); this.coordinate = coordinate; } public VectorType(final List<CoordinateType> coordinate) { this.coordinate = coordinate; } /** * Gets the value of the coordinate property. * */ public List<CoordinateType> getCoordinate() { if (coordinate == null) { coordinate = new ArrayList<CoordinateType>(); } return this.coordinate; } /** * Invoked through Java reflection. */ public void setCoordinate(List<CoordinateType> coordinate) { this.coordinate = coordinate; } private CoordinateType getCoordinate(final String def) { if (coordinate != null) { for (final CoordinateType c : coordinate) { final QuantityType q = c.getQuantity(); if (q != null && def.equals(q.getDefinition())) { return c; } } } return null; } private CoordinateType getCoordinateByName(final String name) { if (coordinate != null) { for (final CoordinateType c : coordinate) { if (c != null && name.equals(c.getName())) { return c; } } } return null; } private void setCoordinate(final String def, final CoordinateType coord) { if (coordinate != null) { final int size = coordinate.size(); for (int i=0; i<size; i++) { final QuantityType q = coordinate.get(i).getQuantity(); if (q != null && def.equals(q.getDefinition())) { coordinate.set(i, coord); return; } } } else { coordinate = new ArrayList<>(3); } coordinate.add(coord); } @Override public AbstractGeometry getGeometry(final URI crs) { final CoordinateType lat = getLatitude(); final CoordinateType lon = getLongitude(); if (isComplete(lat) && isComplete(lon)) { final DirectPositionType dp = new DirectPositionType(lat.getQuantity().getValue(), lon.getQuantity().getValue()); final PointType pt = new PointType(dp); if (crs != null) { pt.setSrsName(crs.toString()); } return pt; } return null; } private boolean isComplete(final CoordinateType c) { return c != null && c.getQuantity() != null && c.getQuantity().getValue() != null; } /** * Returns the coordinate having the {@code "urn:ogc:def:phenomenon:latitude"} definition, or {@code null} if none. */ @Override public CoordinateType getLatitude() { CoordinateType c = getCoordinate("urn:ogc:def:phenomenon:latitude"); if (c == null) { c = getCoordinateByName("northing"); } return c; } /** * Replaces the coordinate having the {@code "urn:ogc:def:phenomenon:latitude"} definition, by the given {@code coord}, * or add the given {@code coord} to the list of coordinates if no latitude existed before this method call. */ public void setLatitude(final CoordinateType coord) { setCoordinate("urn:ogc:def:phenomenon:latitude", coord); } /** * Returns the coordinate having the {@code "urn:ogc:def:phenomenon:longitude"} definition, or {@code null} if none. */ @Override public CoordinateType getLongitude() { CoordinateType c = getCoordinate("urn:ogc:def:phenomenon:longitude"); if (c == null) { c = getCoordinateByName("easting"); } return c; } /** * Replaces the coordinate having the {@code "urn:ogc:def:phenomenon:longitude"} definition, by the given {@code coord}, * or add the given {@code coord} to the list of coordinates if no latitude existed before this method call. */ public void setLongitude(final CoordinateType coord) { setCoordinate("urn:ogc:def:phenomenon:longitude", coord); } /** * Verify if this entry is identical to specified object. */ @Override public boolean equals(final Object object, final ComparisonMode mode) { if (object == this) { return true; } if (object instanceof VectorType && super.equals(object, mode)) { final VectorType that = (VectorType ) object; return Objects.equals(this.coordinate, that.coordinate); } return false; } @Override public int hashCode() { int hash = 3; hash = 23 * hash + (this.coordinate != null ? this.coordinate.hashCode() : 0); return hash; } @Override public String toString() { StringBuilder s = new StringBuilder(super.toString()); if (coordinate != null) { s.append("coordinate:").append(coordinate).append('\n'); } return s.toString(); } }