/**
*
* geo-platform
* Rich webgis framework
* http://geo-platform.org
* ====================================================================
*
* Copyright (C) 2008-2017 geoSDI Group (CNR IMAA - Potenza - ITALY).
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version. This program 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 General Public License
* for more details. You should have received a copy of the GNU General
* Public License along with this program. If not, see http://www.gnu.org/licenses/
*
* ====================================================================
*
* Linking this library statically or dynamically with other modules is
* making a combined work based on this library. Thus, the terms and
* conditions of the GNU General Public License cover the whole combination.
*
* As a special exception, the copyright holders of this library give you permission
* to link this library with independent modules to produce an executable, regardless
* of the license terms of these independent modules, and to copy and distribute
* the resulting executable under terms of your choice, provided that you also meet,
* for each linked independent module, the terms and conditions of the license of
* that module. An independent module is a module which is not derived from or
* based on this library. If you modify this library, you may extend this exception
* to your version of the library, but you are not obligated to do so. If you do not
* wish to do so, delete this exception statement from your version.
*/
//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.5-b10
// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
// Any modifications to this file will be lost upon recompilation of the source schema.
// Generated on: 2012.04.17 at 10:27:36 PM CEST
//
package org.geosdi.geoplatform.xml.gml.v311;
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlSchemaType;
import javax.xml.bind.annotation.XmlSeeAlso;
import javax.xml.bind.annotation.XmlType;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
import org.jvnet.jaxb2_commons.lang.ToString;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
/**
* Envelope defines an extent using a pair of positions defining opposite corners in arbitrary dimensions. The first direct
* position is the "lower corner" (a coordinate position consisting of all the minimal ordinates for each dimension for all points within the envelope),
* the second one the "upper corner" (a coordinate position consisting of all the maximal ordinates for each dimension for all points within the
* envelope).
*
* <p>Java class for EnvelopeType complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="EnvelopeType">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <choice>
* <sequence>
* <element name="lowerCorner" type="{http://www.opengis.net/gml}DirectPositionType"/>
* <element name="upperCorner" type="{http://www.opengis.net/gml}DirectPositionType"/>
* </sequence>
* <element ref="{http://www.opengis.net/gml}coord" maxOccurs="2" minOccurs="2"/>
* <element ref="{http://www.opengis.net/gml}pos" maxOccurs="2" minOccurs="2"/>
* <element ref="{http://www.opengis.net/gml}coordinates"/>
* </choice>
* <attGroup ref="{http://www.opengis.net/gml}SRSReferenceGroup"/>
* </restriction>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "EnvelopeType", propOrder = {
"lowerCorner",
"upperCorner",
"coord",
"pos",
"coordinates"
})
@XmlSeeAlso({
EnvelopeWithTimePeriodType.class
})
public class EnvelopeType implements ToString
{
protected DirectPositionType lowerCorner;
protected DirectPositionType upperCorner;
protected List<CoordType> coord;
protected List<DirectPositionType> pos;
protected CoordinatesType coordinates;
@XmlAttribute(name = "srsName")
@XmlSchemaType(name = "anyURI")
protected String srsName;
@XmlAttribute(name = "srsDimension")
@XmlSchemaType(name = "positiveInteger")
protected BigInteger srsDimension;
@XmlAttribute(name = "axisLabels")
protected List<String> axisLabels;
@XmlAttribute(name = "uomLabels")
protected List<String> uomLabels;
/**
* Gets the value of the lowerCorner property.
*
* @return
* possible object is
* {@link DirectPositionType }
*
*/
public DirectPositionType getLowerCorner() {
return lowerCorner;
}
/**
* Sets the value of the lowerCorner property.
*
* @param value
* allowed object is
* {@link DirectPositionType }
*
*/
public void setLowerCorner(DirectPositionType value) {
this.lowerCorner = value;
}
public boolean isSetLowerCorner() {
return (this.lowerCorner!= null);
}
/**
* Gets the value of the upperCorner property.
*
* @return
* possible object is
* {@link DirectPositionType }
*
*/
public DirectPositionType getUpperCorner() {
return upperCorner;
}
/**
* Sets the value of the upperCorner property.
*
* @param value
* allowed object is
* {@link DirectPositionType }
*
*/
public void setUpperCorner(DirectPositionType value) {
this.upperCorner = value;
}
public boolean isSetUpperCorner() {
return (this.upperCorner!= null);
}
/**
* deprecated with GML version 3.0 Gets the value of the coord property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the coord property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getCoord().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link CoordType }
*
*
*/
public List<CoordType> getCoord() {
if (coord == null) {
coord = new ArrayList<CoordType>();
}
return this.coord;
}
public boolean isSetCoord() {
return ((this.coord!= null)&&(!this.coord.isEmpty()));
}
public void unsetCoord() {
this.coord = null;
}
/**
* Deprecated with GML version 3.1. Use the explicit properties "lowerCorner" and "upperCorner" instead.Gets the value of the pos property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the pos property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getPos().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link DirectPositionType }
*
*
*/
public List<DirectPositionType> getPos() {
if (pos == null) {
pos = new ArrayList<DirectPositionType>();
}
return this.pos;
}
public boolean isSetPos() {
return ((this.pos!= null)&&(!this.pos.isEmpty()));
}
public void unsetPos() {
this.pos = null;
}
/**
* Deprecated with GML version 3.1.0. Use the explicit properties "lowerCorner" and "upperCorner" instead.
*
* @return
* possible object is
* {@link CoordinatesType }
*
*/
public CoordinatesType getCoordinates() {
return coordinates;
}
/**
* Sets the value of the coordinates property.
*
* @param value
* allowed object is
* {@link CoordinatesType }
*
*/
public void setCoordinates(CoordinatesType value) {
this.coordinates = value;
}
public boolean isSetCoordinates() {
return (this.coordinates!= null);
}
/**
* Gets the value of the srsName property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getSrsName() {
return srsName;
}
/**
* Sets the value of the srsName property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setSrsName(String value) {
this.srsName = value;
}
public boolean isSetSrsName() {
return (this.srsName!= null);
}
/**
* Gets the value of the srsDimension property.
*
* @return
* possible object is
* {@link BigInteger }
*
*/
public BigInteger getSrsDimension() {
return srsDimension;
}
/**
* Sets the value of the srsDimension property.
*
* @param value
* allowed object is
* {@link BigInteger }
*
*/
public void setSrsDimension(BigInteger value) {
this.srsDimension = value;
}
public boolean isSetSrsDimension() {
return (this.srsDimension!= null);
}
/**
* Gets the value of the axisLabels property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the axisLabels property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getAxisLabels().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link String }
*
*
*/
public List<String> getAxisLabels() {
if (axisLabels == null) {
axisLabels = new ArrayList<String>();
}
return this.axisLabels;
}
public boolean isSetAxisLabels() {
return ((this.axisLabels!= null)&&(!this.axisLabels.isEmpty()));
}
public void unsetAxisLabels() {
this.axisLabels = null;
}
/**
* Gets the value of the uomLabels property.
*
* <p>
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a <CODE>set</CODE> method for the uomLabels property.
*
* <p>
* For example, to add a new item, do as follows:
* <pre>
* getUomLabels().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link String }
*
*
*/
public List<String> getUomLabels() {
if (uomLabels == null) {
uomLabels = new ArrayList<String>();
}
return this.uomLabels;
}
public boolean isSetUomLabels() {
return ((this.uomLabels!= null)&&(!this.uomLabels.isEmpty()));
}
public void unsetUomLabels() {
this.uomLabels = null;
}
public String toString() {
final ToStringStrategy strategy = JAXBToStringStrategy.INSTANCE;
final StringBuilder buffer = new StringBuilder();
append(null, buffer, strategy);
return buffer.toString();
}
public StringBuilder append(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) {
strategy.appendStart(locator, this, buffer);
appendFields(locator, buffer, strategy);
strategy.appendEnd(locator, this, buffer);
return buffer;
}
public StringBuilder appendFields(ObjectLocator locator, StringBuilder buffer, ToStringStrategy strategy) {
{
DirectPositionType theLowerCorner;
theLowerCorner = this.getLowerCorner();
strategy.appendField(locator, this, "lowerCorner", buffer, theLowerCorner);
}
{
DirectPositionType theUpperCorner;
theUpperCorner = this.getUpperCorner();
strategy.appendField(locator, this, "upperCorner", buffer, theUpperCorner);
}
{
List<CoordType> theCoord;
theCoord = (this.isSetCoord()?this.getCoord():null);
strategy.appendField(locator, this, "coord", buffer, theCoord);
}
{
List<DirectPositionType> thePos;
thePos = (this.isSetPos()?this.getPos():null);
strategy.appendField(locator, this, "pos", buffer, thePos);
}
{
CoordinatesType theCoordinates;
theCoordinates = this.getCoordinates();
strategy.appendField(locator, this, "coordinates", buffer, theCoordinates);
}
{
String theSrsName;
theSrsName = this.getSrsName();
strategy.appendField(locator, this, "srsName", buffer, theSrsName);
}
{
BigInteger theSrsDimension;
theSrsDimension = this.getSrsDimension();
strategy.appendField(locator, this, "srsDimension", buffer, theSrsDimension);
}
{
List<String> theAxisLabels;
theAxisLabels = (this.isSetAxisLabels()?this.getAxisLabels():null);
strategy.appendField(locator, this, "axisLabels", buffer, theAxisLabels);
}
{
List<String> theUomLabels;
theUomLabels = (this.isSetUomLabels()?this.getUomLabels():null);
strategy.appendField(locator, this, "uomLabels", buffer, theUomLabels);
}
return buffer;
}
public void setCoord(List<CoordType> value) {
this.coord = null;
List<CoordType> draftl = this.getCoord();
draftl.addAll(value);
}
public void setPos(List<DirectPositionType> value) {
this.pos = null;
List<DirectPositionType> draftl = this.getPos();
draftl.addAll(value);
}
public void setAxisLabels(List<String> value) {
this.axisLabels = null;
List<String> draftl = this.getAxisLabels();
draftl.addAll(value);
}
public void setUomLabels(List<String> value) {
this.uomLabels = null;
List<String> draftl = this.getUomLabels();
draftl.addAll(value);
}
}