All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.geotools.feature.FeatureCollection Maven / Gradle / Ivy

Go to download

The main module contains the GeoTools public interfaces that are used by other GeoTools modules (and GeoTools applications). Where possible we make use industry standard terms as provided by OGC and ISO standards. The formal GeoTools public api consists of gt-metadata, jts and the gt-main module. The main module contains the default implementations that are available provided to other GeoTools modules using our factory system. Factories are obtained from an appropriate FactoryFinder, giving applications a chance configure the factory used using the Factory Hints facilities. FilterFactory ff = CommonFactoryFinder.getFilterFactory(); Expression expr = ff.add( expression1, expression2 ); If you find yourself using implementation specific classes chances are you doing it wrong: Expression expr = new AddImpl( expression1, expressiom2 );

There is a newer version: 24.2-oss84-1
Show newest version
/*
 *    GeoTools - The Open Source Java GIS Toolkit
 *    http://geotools.org
 *
 *    (C) 2002-2008, Open Source Geospatial Foundation (OSGeo)
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation;
 *    version 2.1 of the License.
 *
 *    This library 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
 *    Lesser General Public License for more details.
 */
package org.geotools.feature;

import java.io.IOException;
import java.util.Collection;
import org.geotools.geometry.jts.ReferencedEnvelope;
import org.opengis.feature.Feature;
import org.opengis.feature.FeatureVisitor;
import org.opengis.feature.type.FeatureType;
import org.opengis.filter.Filter;
import org.opengis.filter.sort.SortBy;
import org.opengis.util.ProgressListener;

/**
 * Collection of features, often handled as a result set.
 *
 * 

Where possible FeatureCollection is method compatible with {@link Collection}. * *

SimpleFeatureCollection house rules: * *

    *
  • Each iterator is considered a live connection which must be closed (see example below) *
  • Features are not specifically ordered within the SimpleFeatureCollection *
  • Two Feature instances cannot exist with the same {@link FeatureId} *
* *

* *

FeatureIterator close

* *

FeatureCollection provides streaming access with the following restriction on the use of * {@link FeatureIterator}: You must call {@link FeatureIterator#close()}. This allows * FeatureCollection to clean up any operating system resources used to access information. * *

Example (safe) use: * *


 * FeatureIterator iterator = featureCollection.features();
 * try {
 *     while( iterator.hasNext() ){
 *          Feature feature = iterator.next();
 *          System.out.println( feature.getID() );
 *     }
 * }
 * finally {
 *     iterator.close();
 * }
 * 
* * And in Java 7: * *

 * try ( FeatureIterator iterator = featureCollection.features() ){
 *     while( iterator.hasNext() ){
 *          Feature feature = iterator.next();
 *          System.out.println( feature.getID() );
 *     }
 * }
 * 
* *

Handy Tip: Although many resource backed collections will choose to release resources at when * the iterator has reached the end of its contents this is not something you should rely on. * *

FeatureCollection Implementation Tips

* *

Auto close: Try and close up resources when you can detect that an Iterator is no longer in * use. * *

Lazy Connect: FeatureCollection is used in two fashions, as a result set, where each iterator * acts as a cursor over the content. Also as a predefined query which can be refined further. An * example is using featureCollection.subCollection( Filter ) or featureCollection.sort( SortBy ) * before listing features out of a FeatureCollection. * * @see org.geotools.Feature * @author Ian Turton, CCG * @author Rob Hranac, VFNY * @author Ian Schneider, USDA-ARS * @author Jody Garnett, LISAsoft * @version $Id$ */ public interface FeatureCollection { /** * Obtain a FeatureIterator of the Features within this FeatureCollection. * *

The implementation of FeatureIterator must adhere to the rules of fail-fast concurrent * modification. In addition (to allow for resource backed collections) the * FeatureIterator.close() method must be called. * *

Example use: * *


     * FeatureIterator iterator=collection.features();
     * try {
     *     while( iterator.hasNext()  ){
     *          Feature feature = iterator.next();
     *          System.out.println( feature.getID() );
     *     }
     * }
     * finally {
     *     iterator.close();
     * }
     * 
* *

GML Note: The contents of this iterator are considered to be defined by * featureMember tags (and/or the single allowed FeatureMembers tag). Please see * getFeatureType for more details. * * @return A FeatureIterator. */ FeatureIterator features(); /** * The schema for the child feature members of this collection. * *

Represents the most general FeatureType in common to all the features in this collection. * *

    *
  • For a collection backed by a shapefiles (or database tables) the FeatureType returned * by getSchema() will complete describe each and every child in the collection. *
  • For mixed content FeatureCollections you will need to check the FeatureType of each * Feature as it is retrived from the collection *
  • The degenerate case returns the "_Feature" FeatureType, where the only thing known is * that the contents are Features. *
* * @return FeatureType describing the "common" schema to all child features of this collection */ T getSchema(); /** ID used when serializing to GML */ String getID(); /** * Visit the contents of a feature collection. * *

The order of traversal is dependent on the FeatureCollection implementation; some * collections are able to make efficient use of an internal index in order to quickly visit * features located in the same region. * * @param visitor Closure applied to each feature in turn. * @param progress Used to report progress, may be used to interrupt the operation * @since 2.5 */ void accepts(FeatureVisitor visitor, ProgressListener progress) throws IOException; /** * SimpleFeatureCollection "view" indicated by provided filter. * *

The contents of the returned SimpleFeatureCollection are determined by applying the * provider Filter to the entire contents of this FeatureCollection. The result is "live" and * modifications will be shared. * *

This method is used cut down on the number of filter based methods required for a useful * SimpleFeatureCollection construct. The FeatureCollections returned really should be * considered as a temporary "view" used to control the range of a removeAll, or modify * operation. * *

Example Use: * *


     * collection.subCollection( filter ).clear();
     * 
* * The above recommended use is agreement with the Collections API precident of List.subList( * start, end ). * *

The results of subCollection: * *

    *
  • are to be considered unordered *
  • may be an ordered FeatureList if requested when sortBy is indicated *
* * @see FeatureList * @return SimpleFeatureCollection identified as subset. */ public FeatureCollection subCollection(Filter filter); /** * Obtained sorted contents. * *

This method may not be supported by all implementations, consider the use of * FeatureSource.features( Query ). * * @param order Sort order * @return FeatureCollection sorted in the indicated order */ public FeatureCollection sort(SortBy order); /** * Get the total bounds of this collection which is calculated by doing a union of the bounds of * each feature inside of it * * @return An Envelope containing the total bounds of this collection. */ ReferencedEnvelope getBounds(); // // ResourceCollection methods // /** @see java.util.Collection#contains(Object) */ boolean contains(Object o); /** @see java.util.Collection#containsAll(Collection) */ boolean containsAll(Collection o); /** * Returns true if this feature collection contains no features. * * @return true if this collection contains no features */ boolean isEmpty(); /** * Please note this operation may be expensive when working with remote content. * * @see java.util.Collection#size() */ int size(); /** @see java.util.Collection#toArray() */ Object[] toArray(); /** @see java.util.Collection#toArray(Object[]) */ O[] toArray(O[] a); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy