/** * * 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.util.ArrayList; import java.util.List; import javax.xml.bind.JAXBElement; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlElementRef; 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; /** * A PolygonPatch is a surface patch that is defined by a set of boundary curves and an underlying surface to which these curves adhere. The curves are coplanar and the polygon uses planar interpolation in its interior. Implements GM_Polygon of ISO 19107. * * <p>Java class for PolygonPatchType complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="PolygonPatchType"> * <complexContent> * <extension base="{http://www.opengis.net/gml}AbstractSurfacePatchType"> * <sequence> * <element ref="{http://www.opengis.net/gml}exterior" minOccurs="0"/> * <element ref="{http://www.opengis.net/gml}interior" maxOccurs="unbounded" minOccurs="0"/> * </sequence> * <attribute name="interpolation" type="{http://www.opengis.net/gml}SurfaceInterpolationType" fixed="planar" /> * </extension> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "PolygonPatchType", propOrder = { "exterior", "interior" }) public class PolygonPatchType extends AbstractSurfacePatchType implements ToString { @XmlElementRef(name = "exterior", namespace = "http://www.opengis.net/gml", type = JAXBElement.class) protected JAXBElement<AbstractRingPropertyType> exterior; @XmlElementRef(name = "interior", namespace = "http://www.opengis.net/gml", type = JAXBElement.class) protected List<JAXBElement<AbstractRingPropertyType>> interior; @XmlAttribute(name = "interpolation") protected SurfaceInterpolationType interpolation; /** * Gets the value of the exterior property. * * @return * possible object is * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * */ public JAXBElement<AbstractRingPropertyType> getExterior() { return exterior; } /** * Sets the value of the exterior property. * * @param value * allowed object is * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * */ public void setExterior(JAXBElement<AbstractRingPropertyType> value) { this.exterior = value; } public boolean isSetExterior() { return (this.exterior!= null); } /** * Gets the value of the interior 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 interior property. * * <p> * For example, to add a new item, do as follows: * <pre> * getInterior().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractRingPropertyType }{@code >} * * */ public List<JAXBElement<AbstractRingPropertyType>> getInterior() { if (interior == null) { interior = new ArrayList<JAXBElement<AbstractRingPropertyType>>(); } return this.interior; } public boolean isSetInterior() { return ((this.interior!= null)&&(!this.interior.isEmpty())); } public void unsetInterior() { this.interior = null; } /** * Gets the value of the interpolation property. * * @return * possible object is * {@link SurfaceInterpolationType } * */ public SurfaceInterpolationType getInterpolation() { if (interpolation == null) { return SurfaceInterpolationType.PLANAR; } else { return interpolation; } } /** * Sets the value of the interpolation property. * * @param value * allowed object is * {@link SurfaceInterpolationType } * */ public void setInterpolation(SurfaceInterpolationType value) { this.interpolation = value; } public boolean isSetInterpolation() { return (this.interpolation!= 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) { super.appendFields(locator, buffer, strategy); { JAXBElement<AbstractRingPropertyType> theExterior; theExterior = this.getExterior(); strategy.appendField(locator, this, "exterior", buffer, theExterior); } { List<JAXBElement<AbstractRingPropertyType>> theInterior; theInterior = (this.isSetInterior()?this.getInterior():null); strategy.appendField(locator, this, "interior", buffer, theInterior); } { SurfaceInterpolationType theInterpolation; theInterpolation = this.getInterpolation(); strategy.appendField(locator, this, "interpolation", buffer, theInterpolation); } return buffer; } public void setInterior(List<JAXBElement<AbstractRingPropertyType>> value) { this.interior = null; List<JAXBElement<AbstractRingPropertyType>> draftl = this.getInterior(); draftl.addAll(value); } }