/[schmitzm]/trunk/src/skrueger/geotools/StyledFeaturesInterface.java
ViewVC logotype

Diff of /trunk/src/skrueger/geotools/StyledFeaturesInterface.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 256 by alfonx, Fri Jul 31 14:43:47 2009 UTC revision 1261 by alfonx, Thu Nov 11 13:12:50 2010 UTC
# Line 25  Line 25 
25   *   *
26   * Contributors:   * Contributors:
27   *     Martin O. J. Schmitz - initial API and implementation   *     Martin O. J. Schmitz - initial API and implementation
28   *     Stefan A. Krüger - additional utility classes   *     Stefan A. Tzeggai - additional utility classes
29   ******************************************************************************/   ******************************************************************************/
30  package skrueger.geotools;  package skrueger.geotools;
31    
 import java.util.Map;  
   
32  import org.geotools.data.FeatureSource;  import org.geotools.data.FeatureSource;
33  import org.geotools.feature.FeatureCollection;  import org.geotools.feature.FeatureCollection;
34    import org.opengis.feature.simple.SimpleFeature;
35    import org.opengis.feature.simple.SimpleFeatureType;
36    import org.opengis.filter.Filter;
37    
38  import skrueger.AttributeMetaData;  import schmitzm.geotools.feature.FeatureUtil.GeometryForm;
39    import skrueger.AttributeMetadataImpl;
40    
41  /**  /**
42   * This Interface combines all styled layers that are running on   * This Interface combines all styled layers that are running on
43   * {@link FeatureCollection} or {@link FeatureSource}   * {@link FeatureCollection} or {@link FeatureSource}
44   *   *
45   * @author Stefan A. Krüger   * @author Stefan A. Tzeggai
46   *   *
47   * @param <T>   * @param <T>
48   *            The base Type returned in the getObject() method.   *            The base Type returned in the getObject() method.
49   */   */
50  public interface StyledFeaturesInterface<T> extends StyledLayerInterface<T> {  public interface StyledFeaturesInterface<T> extends StyledLayerInterface<T> {
51    
52          public abstract Map<Integer, AttributeMetaData> getAttributeMetaDataMap();          public abstract AttributeMetadataMap<AttributeMetadataImpl> getAttributeMetaDataMap();
53    
54            /**
55             * @return The features of this layer as a {@link FeatureSource}. The filter
56             *         is NOT automatically applied.
57             */
58            public FeatureSource<SimpleFeatureType, SimpleFeature> getFeatureSource();
59    
60            /**
61             * @return The features of this layer as a {@link FeatureCollection}. The
62             *         filter is NOT automatically applied.
63             */
64            public abstract FeatureCollection<SimpleFeatureType, SimpleFeature> getFeatureCollection();
65    
66            /**
67             * @return The features of this layer as a {@link FeatureCollection}. The
68             *         associated Filter is automatically applied.
69             */
70            public abstract FeatureCollection<SimpleFeatureType, SimpleFeature> getFeatureCollectionFiltered();
71    
72            /**
73             * Stores Filter that is NOT automatically applied. <code>null</code> is not
74             * allowed, use Filter.INCLUDE.
75             */
76            public void setFilter(Filter filter);
77    
78          /**          /**
79           * @return The features of this layer as a {@link FeatureSource}.           * Returns the Filter a filter that is associated with this
80             * {@link StyledFeaturesInterface} Never shall return <code>null</code>, but
81             * rather Filter.INCLUDE.
82           */           */
83          public FeatureSource getFeatureSource();          public Filter getFilter();
84    
85          /**          /**
86           * @return The features of this layer as a {@link FeatureCollection}.           * Returns the underlying GeoTools Object. The filter is NOT applied.
87             *
88             * @throws RuntimeException
89             *
90             * @deprected Please use {@link #getFeatureSource()} or
91             *            {@link #getFeatureCollection()} so you save a cast
92           */           */
93          public abstract FeatureCollection getFeatureCollection();          public T getGeoObject();
94    
95            /**
96             * @return As the fastest way to get the Schema is depending on the
97             *         underlying geoObject (FeatureSource or FeatureCollection), this
98             *         method shall be implemented in the classes.
99             */
100            public abstract SimpleFeatureType getSchema();
101    
102            public abstract GeometryForm getGeometryForm();
103    
104  }  }

Legend:
Removed from v.256  
changed lines
  Added in v.1261

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26