001    //$HeadURL: https://svn.wald.intevation.org/svn/deegree/base/branches/2.3_testing/src/org/deegree/model/spatialschema/MultiSurface.java $
002    /*----------------------------------------------------------------------------
003     This file is part of deegree, http://deegree.org/
004     Copyright (C) 2001-2009 by:
005       Department of Geography, University of Bonn
006     and
007       lat/lon GmbH
008    
009     This library is free software; you can redistribute it and/or modify it under
010     the terms of the GNU Lesser General Public License as published by the Free
011     Software Foundation; either version 2.1 of the License, or (at your option)
012     any later version.
013     This library is distributed in the hope that it will be useful, but WITHOUT
014     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
015     FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
016     details.
017     You should have received a copy of the GNU Lesser General Public License
018     along with this library; if not, write to the Free Software Foundation, Inc.,
019     59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
020    
021     Contact information:
022    
023     lat/lon GmbH
024     Aennchenstr. 19, 53177 Bonn
025     Germany
026     http://lat-lon.de/
027    
028     Department of Geography, University of Bonn
029     Prof. Dr. Klaus Greve
030     Postfach 1147, 53001 Bonn
031     Germany
032     http://www.geographie.uni-bonn.de/deegree/
033    
034     e-mail: info@deegree.org
035    ----------------------------------------------------------------------------*/
036    
037    package org.deegree.model.spatialschema;
038    
039    /**
040     *
041     * This Interface defines the Aggregation of Surfaces. The implementing class should encapsulate a java.util.Vector or a
042     * comparative data structure.
043     *
044     * <p>
045     * -----------------------------------------------------
046     * </p>
047     *
048     * @author Andreas Poth
049     * @version $Revision: 18195 $ $Date: 2009-06-18 17:55:39 +0200 (Do, 18. Jun 2009) $
050     *          <p>
051     */
052    
053    public interface MultiSurface extends MultiPrimitive {
054    
055        /**
056         * adds an Surface to the aggregation
057         *
058         * @param surface
059         */
060        public void addSurface( Surface surface );
061    
062        /**
063         * inserts a Surface in the aggregation. all elements with an index equal or larger index will be moved. if index is
064         * larger then getSize() - 1 or smaller then 0 or surface equals null an exception will be thrown.
065         *
066         * @param surface
067         *            Surface to insert.
068         * @param index
069         *            position where to insert the new Surface
070         * @throws GeometryException
071         */
072        public void insertSurfaceAt( Surface surface, int index )
073                                throws GeometryException;
074    
075        /**
076         * sets the submitted Surface at the submitted index. the element at the position <code>index</code> will be
077         * removed. if index is larger then getSize() - 1 or smaller then 0 or surface equals null an exception will be
078         * thrown.
079         *
080         * @param surface
081         *            Surface to set.
082         * @param index
083         *            position where to set the new Surface
084         * @throws GeometryException
085         */
086        public void setSurfaceAt( Surface surface, int index )
087                                throws GeometryException;
088    
089        /**
090         * removes the submitted Surface from the aggregation
091         *
092         * @param surface
093         *
094         * @return the removed Surface
095         */
096        public Surface removeSurface( Surface surface );
097    
098        /**
099         * removes the Surface at the submitted index from the aggregation. if index is larger then getSize() - 1 or smaller
100         * then 0 an exception will be thrown.
101         *
102         * @param index
103         *
104         * @return the removed Surface
105         * @throws GeometryException
106         */
107        public Surface removeSurfaceAt( int index )
108                                throws GeometryException;
109    
110        /**
111         * returns the Surface at the submitted index.
112         *
113         * @param index
114         * @return the Surface at the submitted index.
115         */
116        public Surface getSurfaceAt( int index );
117    
118        /**
119         * returns all Surfaces as an array
120         *
121         * @return all Surfaces as an array
122         */
123        public Surface[] getAllSurfaces();
124    
125        /**
126         * returns the area of a MultiSurface
127         *
128         * @return the area of a MultiSurface
129         */
130        public double getArea();
131    
132    }