/** * * 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.JAXBElement; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlElementRef; import javax.xml.bind.annotation.XmlElementRefs; 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; /** * This variant of the arc computes the mid points of the arcs instead of storing the coordinates directly. The control point sequence consists of the start and end points of each arc plus the bulge. * * <p>Java class for ArcStringByBulgeType complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="ArcStringByBulgeType"> * <complexContent> * <extension base="{http://www.opengis.net/gml}AbstractCurveSegmentType"> * <sequence> * <choice> * <choice maxOccurs="unbounded" minOccurs="2"> * <element ref="{http://www.opengis.net/gml}pos"/> * <element ref="{http://www.opengis.net/gml}pointProperty"/> * <element ref="{http://www.opengis.net/gml}pointRep"/> * </choice> * <element ref="{http://www.opengis.net/gml}posList"/> * <element ref="{http://www.opengis.net/gml}coordinates"/> * </choice> * <element name="bulge" type="{http://www.w3.org/2001/XMLSchema}double" maxOccurs="unbounded"/> * <element name="normal" type="{http://www.opengis.net/gml}VectorType" maxOccurs="unbounded"/> * </sequence> * <attribute name="interpolation" type="{http://www.opengis.net/gml}CurveInterpolationType" fixed="circularArc2PointWithBulge" /> * <attribute name="numArc" type="{http://www.w3.org/2001/XMLSchema}integer" /> * </extension> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "ArcStringByBulgeType", propOrder = { "posOrPointPropertyOrPointRep", "posList", "coordinates", "bulge", "normal" }) @XmlSeeAlso({ ArcByBulgeType.class }) public class ArcStringByBulgeType extends AbstractCurveSegmentType implements ToString { @XmlElementRefs({ @XmlElementRef(name = "pointProperty", namespace = "http://www.opengis.net/gml", type = JAXBElement.class), @XmlElementRef(name = "pointRep", namespace = "http://www.opengis.net/gml", type = JAXBElement.class), @XmlElementRef(name = "pos", namespace = "http://www.opengis.net/gml", type = JAXBElement.class) }) protected List<JAXBElement<?>> posOrPointPropertyOrPointRep; protected DirectPositionListType posList; protected CoordinatesType coordinates; @XmlElement(type = Double.class) protected List<Double> bulge; @XmlElement(required = true) protected List<VectorType> normal; @XmlAttribute(name = "interpolation") protected CurveInterpolationType interpolation; @XmlAttribute(name = "numArc") protected BigInteger numArc; /** * Gets the value of the posOrPointPropertyOrPointRep 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 posOrPointPropertyOrPointRep property. * * <p> * For example, to add a new item, do as follows: * <pre> * getPosOrPointPropertyOrPointRep().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link JAXBElement }{@code <}{@link DirectPositionType }{@code >} * {@link JAXBElement }{@code <}{@link PointPropertyType }{@code >} * {@link JAXBElement }{@code <}{@link PointPropertyType }{@code >} * * */ public List<JAXBElement<?>> getPosOrPointPropertyOrPointRep() { if (posOrPointPropertyOrPointRep == null) { posOrPointPropertyOrPointRep = new ArrayList<JAXBElement<?>>(); } return this.posOrPointPropertyOrPointRep; } public boolean isSetPosOrPointPropertyOrPointRep() { return ((this.posOrPointPropertyOrPointRep!= null)&&(!this.posOrPointPropertyOrPointRep.isEmpty())); } public void unsetPosOrPointPropertyOrPointRep() { this.posOrPointPropertyOrPointRep = null; } /** * Gets the value of the posList property. * * @return * possible object is * {@link DirectPositionListType } * */ public DirectPositionListType getPosList() { return posList; } /** * Sets the value of the posList property. * * @param value * allowed object is * {@link DirectPositionListType } * */ public void setPosList(DirectPositionListType value) { this.posList = value; } public boolean isSetPosList() { return (this.posList!= null); } /** * Deprecated with GML version 3.1.0. Use "posList" 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 bulge 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 bulge property. * * <p> * For example, to add a new item, do as follows: * <pre> * getBulge().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link Double } * * */ public List<Double> getBulge() { if (bulge == null) { bulge = new ArrayList<Double>(); } return this.bulge; } public boolean isSetBulge() { return ((this.bulge!= null)&&(!this.bulge.isEmpty())); } public void unsetBulge() { this.bulge = null; } /** * Gets the value of the normal 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 normal property. * * <p> * For example, to add a new item, do as follows: * <pre> * getNormal().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link VectorType } * * */ public List<VectorType> getNormal() { if (normal == null) { normal = new ArrayList<VectorType>(); } return this.normal; } public boolean isSetNormal() { return ((this.normal!= null)&&(!this.normal.isEmpty())); } public void unsetNormal() { this.normal = null; } /** * Gets the value of the interpolation property. * * @return * possible object is * {@link CurveInterpolationType } * */ public CurveInterpolationType getInterpolation() { if (interpolation == null) { return CurveInterpolationType.CIRCULAR_ARC_2_POINT_WITH_BULGE; } else { return interpolation; } } /** * Sets the value of the interpolation property. * * @param value * allowed object is * {@link CurveInterpolationType } * */ public void setInterpolation(CurveInterpolationType value) { this.interpolation = value; } public boolean isSetInterpolation() { return (this.interpolation!= null); } /** * Gets the value of the numArc property. * * @return * possible object is * {@link BigInteger } * */ public BigInteger getNumArc() { return numArc; } /** * Sets the value of the numArc property. * * @param value * allowed object is * {@link BigInteger } * */ public void setNumArc(BigInteger value) { this.numArc = value; } public boolean isSetNumArc() { return (this.numArc!= 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); { List<JAXBElement<?>> thePosOrPointPropertyOrPointRep; thePosOrPointPropertyOrPointRep = (this.isSetPosOrPointPropertyOrPointRep()?this.getPosOrPointPropertyOrPointRep():null); strategy.appendField(locator, this, "posOrPointPropertyOrPointRep", buffer, thePosOrPointPropertyOrPointRep); } { DirectPositionListType thePosList; thePosList = this.getPosList(); strategy.appendField(locator, this, "posList", buffer, thePosList); } { CoordinatesType theCoordinates; theCoordinates = this.getCoordinates(); strategy.appendField(locator, this, "coordinates", buffer, theCoordinates); } { List<Double> theBulge; theBulge = (this.isSetBulge()?this.getBulge():null); strategy.appendField(locator, this, "bulge", buffer, theBulge); } { List<VectorType> theNormal; theNormal = (this.isSetNormal()?this.getNormal():null); strategy.appendField(locator, this, "normal", buffer, theNormal); } { CurveInterpolationType theInterpolation; theInterpolation = this.getInterpolation(); strategy.appendField(locator, this, "interpolation", buffer, theInterpolation); } { BigInteger theNumArc; theNumArc = this.getNumArc(); strategy.appendField(locator, this, "numArc", buffer, theNumArc); } return buffer; } public void setPosOrPointPropertyOrPointRep(List<JAXBElement<?>> value) { this.posOrPointPropertyOrPointRep = null; List<JAXBElement<?>> draftl = this.getPosOrPointPropertyOrPointRep(); draftl.addAll(value); } public void setBulge(List<Double> value) { this.bulge = null; List<Double> draftl = this.getBulge(); draftl.addAll(value); } public void setNormal(List<VectorType> value) { this.normal = null; List<VectorType> draftl = this.getNormal(); draftl.addAll(value); } }