package net.refractions.linecleaner.cleansing.test;
import java.io.File;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import junit.framework.TestCase;
import net.refractions.linecleaner.cleansing.DouglasPeuckerProcessor;
import net.refractions.linecleaner.cleansing.PseudoNodeProcessor;
import org.geotools.data.FeatureSource;
import org.geotools.data.FeatureStore;
import org.geotools.data.shapefile.indexed.IndexedShapefileDataStore;
import org.geotools.data.shapefile.indexed.IndexedShapefileDataStoreFactory;
import org.geotools.resources.TestData;
public class DouglasPeuckerProcessorTest extends TestCase {
private IndexedShapefileDataStore ds;
private String typeName;
private FeatureSource source;
private FeatureStore featureStore;
protected void setUp() throws Exception {
super.setUp();
long before = System.currentTimeMillis();
ds = getDataStore("sam.shp");
typeName = ds.getTypeNames()[0];
source = ds.getFeatureSource( typeName );
featureStore = (FeatureStore) ds.getFeatureSource();
System.out.println(source.getFeatures().getCount());
long after = System.currentTimeMillis();
after = after-before;
System.out.println("Startup time: " + after);
}
public IndexedShapefileDataStore getDataStore(String filename) throws Exception {
File shp = TestData.file( this, filename );
Map params=new HashMap();
params.put( IndexedShapefileDataStoreFactory.URLP.key, shp.toURL());
params.put( IndexedShapefileDataStoreFactory.CREATE_SPATIAL_INDEX.key, new Boolean(true));
params.put( IndexedShapefileDataStoreFactory.MEMORY_MAPPED.key, new Boolean(false));
params.put( IndexedShapefileDataStoreFactory.SPATIAL_INDEX_TYPE.key, IndexedShapefileDataStoreFactory.TREE_GRX);
// params.put( IndexedShapefileDataStoreFactory.SPATIAL_INDEX_TYPE.key, IndexedShapefileDataStoreFactory.TREE_QIX);
Logger.getLogger("org.geotools.data").setLevel(Level.WARNING);
IndexedShapefileDataStoreFactory fac=new IndexedShapefileDataStoreFactory();
return (IndexedShapefileDataStore) fac.createDataStore(params);
}
public void testDP() throws Exception {
PseudoNodeProcessor pnp = new PseudoNodeProcessor(featureStore);
pnp.run();
DouglasPeuckerProcessor dpProcessor = new DouglasPeuckerProcessor(featureStore, 5);
dpProcessor.run();
}
}