Package weave.geometrystream

Source Code of weave.geometrystream.SHPGeometryStreamUtils

/*
    Weave (Web-based Analysis and Visualization Environment)
    Copyright (C) 2008-2011 University of Massachusetts Lowell

    This file is a part of Weave.

    Weave is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License, Version 3,
    as published by the Free Software Foundation.

    Weave 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 Weave.  If not, see <http://www.gnu.org/licenses/>.
*/

package weave.geometrystream;

import java.io.IOException;
import java.net.URL;
import java.util.List;

import org.geotools.data.FeatureReader;
import org.geotools.data.Query;
import org.geotools.data.shapefile.ShapefileDataStore;
import org.geotools.data.shapefile.ShapefileUtilities;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.feature.simple.SimpleFeatureType;
import org.opengis.feature.type.AttributeDescriptor;
import org.opengis.referencing.crs.CoordinateReferenceSystem;

import com.vividsolutions.jts.geom.Geometry;

/**
* Static functions for converting SHP files using a GeometryStreamConverter.
*
* @author adufilie
*/
public class SHPGeometryStreamUtils
{
  public static void convertShapefile(GeometryStreamConverter converter, String filename, List<String> attributes) throws Exception
  {
    boolean debugTime = true;
    long startTime = System.currentTimeMillis();
   
    ShapefileDataStore dataStore = new ShapefileDataStore(new URL("file:///"+filename));
   
    try
    {
      convertFeatures(converter, dataStore, attributes);
    }
    finally
    {
      dataStore.dispose();
    }
   
    long endTime = System.currentTimeMillis();
    if (debugTime)
      System.out.println(String.format("file parsing took %s ms for %s", endTime - startTime, filename));
  }

  /**
   * @param dataStore A ShapeFileDataStore containing geometries to convert.
   * @param keyAttributes The names of attributes to be concatenated to generate record keys.
   * @throws Exception
   */
  public static void convertFeatures(GeometryStreamConverter converter, ShapefileDataStore dataStore, List<String> keyAttributes) throws Exception
  {
    SimpleFeatureType schema = dataStore.getSchema();
    int numFeatures = dataStore.getCount(Query.ALL);
    FeatureReader<SimpleFeatureType, SimpleFeature> reader = null;
    try
    {
      List<AttributeDescriptor> attrDesc = schema.getAttributeDescriptors();
      String header = "\"the_geom_id\", \"the_geom_key\"";
      for (int i = 1; i < attrDesc.size(); i++)
      {
        String colName = attrDesc.get(i).getLocalName();
        if (GeometryStreamConverter.debugDBF)
          header += ", \"" + colName + '"';
        // if any specified attribute matches colName, case insensitive, overwrite specified attribute name with name having correct case
        for (int j = 0; j < keyAttributes.size(); j++)
          if (keyAttributes.get(j).equalsIgnoreCase(colName))
            keyAttributes.set(j, colName);
      }
      // debug: read schema and print it out
      if (GeometryStreamConverter.debugDBF)
        System.out.println(header);
     
      // loop through features and parse them
      long startTime = System.currentTimeMillis(), endTime = startTime, debugInterval = 60000, nextDebugTime = startTime + debugInterval;
      int featureCount = 0;

      reader = dataStore.getFeatureReader();
      CoordinateReferenceSystem projection = schema.getCoordinateReferenceSystem(); // may be null
      String projectionWKT = projection == null ? null : projection.toWKT();
     
      while (reader.hasNext())
      {
        endTime = System.currentTimeMillis();
        if (GeometryStreamConverter.debugTime && endTime > nextDebugTime)
        {
          System.out.println(String.format("Processing %s/%s features, %s minutes elapsed", featureCount, numFeatures, (endTime - startTime)/60000.0));
          while (endTime > nextDebugTime)
            nextDebugTime += debugInterval;
        }
        convertFeature(converter, reader.next(), keyAttributes, projectionWKT);
        featureCount++;
      }
     
      if (GeometryStreamConverter.debugTime && endTime-startTime > debugInterval)
        System.out.println(String.format("Processing %s features completed in %s minutes", numFeatures, (endTime - startTime)/60000.0));
    }
    catch (OutOfMemoryError e)
    {
      e.printStackTrace();
      throw e;
    }
    finally
    {
      try {
        if (reader != null)
          reader.close();
      } catch (IOException e) { }
    }
  }
 
  private static void convertFeature(GeometryStreamConverter converter, SimpleFeature feature, List<String> keyAttributes, String projectionWKT) throws Exception
  {
    int shapeType = GeometryStreamUtils.getShapeTypeFromGeometryType(feature.getType().getType(0).getName().toString());
    // get shape key by concatenating specified attributes
    String shapeKey = "";
    for (int attrIndex = 0; attrIndex < keyAttributes.size(); attrIndex++)
    {
      Object attributeObject = feature.getAttribute(keyAttributes.get(attrIndex));
      shapeKey += ShapefileUtilities.forAttribute(attributeObject, String.class);
    }
    IFeatureGeometryStream geomStream = new JTSFeatureGeometryStream((Geometry)feature.getDefaultGeometry());
    converter.convertFeature(geomStream, shapeType, shapeKey, projectionWKT);

    /*
    if (debugDBF)
    {
      // debug: print data
      String attrs = geometryMetadata.shapeID + ", " + "\"" + shapeKey + '"';
      for (int i = 1; i < feature.getAttributeCount(); i++)
        attrs += ", \"" + feature.getAttribute(i) + '"';
      System.out.println(attrs);
    }
    if (debugCounts)
    {
      System.out.println(String.format("%s (geom %s) has %s vertices", shapeKey, i, coords.length));
    }
    */
  }
}
 
TOP

Related Classes of weave.geometrystream.SHPGeometryStreamUtils

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.