當前位置: 首頁>>代碼示例>>Java>>正文


Java SimpleFeatureCollection.features方法代碼示例

本文整理匯總了Java中org.geotools.data.simple.SimpleFeatureCollection.features方法的典型用法代碼示例。如果您正苦於以下問題:Java SimpleFeatureCollection.features方法的具體用法?Java SimpleFeatureCollection.features怎麽用?Java SimpleFeatureCollection.features使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.geotools.data.simple.SimpleFeatureCollection的用法示例。


在下文中一共展示了SimpleFeatureCollection.features方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: correctFeatures

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
public static SimpleFeatureCollection correctFeatures(SimpleFeatureCollection fc){
 	SimpleFeatureIterator iterator=fc.features();
 	DefaultFeatureCollection outVector = new DefaultFeatureCollection();

 	while(iterator.hasNext()){
 		SimpleFeature sf=iterator.next();
 		Geometry gm=(Geometry)sf.getDefaultGeometry();
 		if(!gm.isValid()){
 			gm=JTSUtil.repair(gm);
 			System.out.println(gm.isValid());
 		}
sf.setDefaultGeometry(gm);
   outVector.add(sf);

 	}

 	return fc;
 }
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:19,代碼來源:SimpleShapefile.java

示例2: testGreaterDateFilterLong

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testGreaterDateFilterLong() throws Exception {
    init();
    Date testDate = new Date(1005912798000l);
    FilterFactory ff = dataStore.getFilterFactory();

    Filter f = ff.greaterOrEqual(ff.property("installed_td"), ff.literal(testDate.getTime()));
    SimpleFeatureCollection features = featureSource.getFeatures(f);
    assertEquals(7, features.size());
    SimpleFeatureIterator it = features.features();
    while (it.hasNext()) {
        SimpleFeature next = it.next();
        Date date = (Date) next.getAttribute("installed_td");
        assertTrue(date.after(testDate) || date.equals(testDate));
    }
    it.close();
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:18,代碼來源:ElasticTemporalFilterIT.java

示例3: testAlternateGeometry

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testAlternateGeometry() throws Exception {
    init("active", "geo2");
    SimpleFeatureType schema = featureSource.getSchema();
    GeometryDescriptor gd = schema.getGeometryDescriptor();
    assertNotNull(gd);
    assertEquals("geo2", gd.getLocalName());

    FilterFactory2 ff = (FilterFactory2) dataStore.getFilterFactory();
    BBOX bbox = ff.bbox("geo2", 6.5, 23.5, 7.5, 24.5, "EPSG:4326");
    SimpleFeatureCollection features = featureSource.getFeatures(bbox);
    assertEquals(1, features.size());
    SimpleFeatureIterator fsi = features.features();
    assertTrue(fsi.hasNext());
    assertEquals(fsi.next().getID(), "active.09");
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:17,代碼來源:ElasticGeometryFilterIT.java

示例4: readFeatures

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
private List<Map<String, Object>> readFeatures(SimpleFeatureCollection features) {
    final ObjectMapper mapper = new ObjectMapper();

    final List<Map<String, Object>> buckets = new ArrayList<>();
    try (SimpleFeatureIterator iterator = features.features()) {
        while (iterator.hasNext()) {
            final SimpleFeature feature = iterator.next();
            if (feature.getAttribute("_aggregation") != null) {
                final byte[] data = (byte[]) feature.getAttribute("_aggregation");
                try {
                    final Map<String,Object> aggregation = mapper.readValue(data, new TypeReference<Map<String,Object>>() {});
                    buckets.add(aggregation);
                } catch (IOException e) {
                    LOGGER.fine("Failed to parse aggregation value: " + e);
                }
            }
        }
    }
    return buckets;
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:21,代碼來源:GeoHashGrid.java

示例5: testOgrStyleGeoPoint

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testOgrStyleGeoPoint() throws Exception {
    init("not-active","geo4.coordinates");
    FilterFactory2 ff = (FilterFactory2) dataStore.getFilterFactory();
    BBOX bbox = ff.bbox("geo4.coordinates", 0, 0, 5, 5, "EPSG:4326");
    assertNotNull(featureSource.getSchema().getDescriptor("geo4.coordinates"));
    assertNull(featureSource.getSchema().getDescriptor("geo4.type"));

    SimpleFeatureCollection features = featureSource.getFeatures(bbox);
    assertEquals(1, features.size());
    SimpleFeatureIterator fsi = features.features();
    assertTrue(fsi.hasNext());
    SimpleFeature feature = fsi.next();
    assertEquals(feature.getID(), "active.13");
    assertNotNull(feature.getDefaultGeometry());
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:17,代碼來源:ElasticGeometryFilterIT.java

示例6: testDisjointFilter

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testDisjointFilter() throws Exception {
    init("not-active","geo3");
    FilterFactory2 ff = (FilterFactory2) dataStore.getFilterFactory();
    GeometryFactory gf = new GeometryFactory();
    PackedCoordinateSequenceFactory sf = new PackedCoordinateSequenceFactory();
    Point ls = gf.createPoint(sf.create(new double[] { 0, 0 }, 2));
    Disjoint f = ff.disjoint(ff.property("geo3"), ff.literal(ls));
    SimpleFeatureCollection features = featureSource.getFeatures(f);
    assertEquals(2, features.size());
    SimpleFeatureIterator fsi = features.features();
    assertTrue(fsi.hasNext());
    assertEquals(fsi.next().getID(), "active.12");
    assertTrue(fsi.hasNext());
    assertEquals(fsi.next().getID(), "active.13");
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:17,代碼來源:ElasticGeometryFilterIT.java

示例7: testLessDateFilterLong

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testLessDateFilterLong() throws Exception {
    init();
    Date testDate = new Date(1005912798000l);
    FilterFactory ff = dataStore.getFilterFactory();

    Filter f = ff.lessOrEqual(ff.property("installed_td"), ff.literal(testDate.getTime()));
    SimpleFeatureCollection features = featureSource.getFeatures(f);
    assertEquals(4, features.size());
    SimpleFeatureIterator it = features.features();
    while (it.hasNext()) {
        SimpleFeature next = it.next();
        Date date = (Date) next.getAttribute("installed_td");
        assertTrue(date.before(testDate) || date.equals(testDate));
    }
    it.close();
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:18,代碼來源:ElasticTemporalFilterIT.java

示例8: joinFeaures

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
/**
 *
 * @param shapes
 * @param shapes2
 * @throws Exception
 */
private static SimpleFeatureCollection joinFeaures(SimpleFeatureSource shapes, SimpleFeatureSource shapes2) throws Exception {
	SimpleFeatureCollection join =null;

    SimpleFeatureType schema = shapes.getSchema();
    String typeName = schema.getTypeName();
    String geomName = schema.getGeometryDescriptor().getLocalName();

    SimpleFeatureType schema2 = shapes2.getSchema();
    String typeName2 = schema2.getTypeName();
    String geomName2 = schema2.getGeometryDescriptor().getLocalName();
    FilterFactory2 ff = CommonFactoryFinder.getFilterFactory2();

    Query outerGeometry = new Query(typeName, Filter.INCLUDE, new String[] { geomName });
    SimpleFeatureCollection outerFeatures = shapes.getFeatures(outerGeometry);
    SimpleFeatureIterator iterator = outerFeatures.features();
    int max = 0;
    try {
        while (iterator.hasNext()) {
            SimpleFeature feature = iterator.next();
            try {
                Geometry geometry = (Geometry) feature.getDefaultGeometry();
                if (!geometry.isValid()) {
                    // skip bad data
                    continue;
                }
                Filter innerFilter = ff.intersects(ff.property(geomName2), ff.literal(geometry));
                Query innerQuery = new Query(typeName2, innerFilter, Query.NO_NAMES);
                join = shapes2.getFeatures(innerQuery);
                int size = join.size();
                max = Math.max(max, size);
            } catch (Exception skipBadData) {
            }
        }
    } finally {
        iterator.close();
    }
    return join;
}
 
開發者ID:ec-europa,項目名稱:sumo,代碼行數:45,代碼來源:SimpleShapefile.java

示例9: readAttributes

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
/**
 * Read attributes.
 *
 * @param attributeData the attribute data
 */
/* (non-Javadoc)
 * @see com.sldeditor.datasource.DataSourceInterface#updateAttributes(com.sldeditor.render.iface.RenderAttributeDataInterface)
 */
@Override
public void readAttributes(DataSourceAttributeListInterface attributeData) {
    if(attributeData == null)
    {
        return;
    }

    List<DataSourceAttributeData> valueMap = new ArrayList<DataSourceAttributeData>();

    SimpleFeatureCollection featureCollection = dataSourceInfo.getFeatureCollection();
    if(featureCollection != null)
    {
        SimpleFeatureIterator iterator = featureCollection.features();
        if(iterator.hasNext())
        {
            SimpleFeature feature = iterator.next();

            List<Object> attributes = feature.getAttributes();
            for (int i = 0; i < attributes.size(); i++)
            {
                Name fieldName = fieldNameMap.get(i);

                DataSourceAttributeData data = new DataSourceAttributeData(fieldName,
                        fieldTypeMap.get(i),
                        attributes.get(i));

                valueMap.add(data);
            }
        }
    }

    attributeData.setData(valueMap);
}
 
開發者ID:robward-scisys,項目名稱:sldeditor,代碼行數:42,代碼來源:DataSourceImpl.java

示例10: determineGeometryType

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
/**
 * Determine geometry type.
 *
 * @param geometryDescriptor the geometry descriptor
 * @param simpleFeatureCollection the simple feature collection
 * @return the geometry type enum
 */
public static GeometryTypeEnum determineGeometryType(GeometryDescriptor geometryDescriptor,
        SimpleFeatureCollection simpleFeatureCollection) {

    if (geometryDescriptor == null) {
        return GeometryTypeEnum.UNKNOWN;
    }

    if (simpleFeatureCollection == null) {
        return GeometryTypeEnum.UNKNOWN;
    }

    Class<?> bindingType = geometryDescriptor.getType().getBinding();

    if (bindingType == Geometry.class) {
        Name geometryName = geometryDescriptor.getName();
        SimpleFeatureIterator iterator = simpleFeatureCollection.features();

        List<GeometryTypeEnum> geometryFeatures = new ArrayList<GeometryTypeEnum>();

        while (iterator.hasNext()) {
            SimpleFeature feature = iterator.next();

            Object value = feature.getAttribute(geometryName);

            if (value != null) {
                GeometryTypeEnum geometryType = GeometryTypeMapping
                        .getGeometryType(value.getClass());

                if (!geometryFeatures.contains(geometryType)) {
                    geometryFeatures.add(geometryType);
                }
            }
        }
        return (combineGeometryType(geometryFeatures));
    } else {
        return GeometryTypeMapping.getGeometryType(bindingType);
    }
}
 
開發者ID:robward-scisys,項目名稱:sldeditor,代碼行數:46,代碼來源:InlineFeatureUtils.java

示例11: selectFirst

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
private SimpleFeature selectFirst(SimpleFeatureCollection features) {
  SimpleFeature first = null;
  try (FeatureIterator<SimpleFeature> iterator = features.features()) {
    if (iterator.hasNext()) {
      first = iterator.next();
    }
  }
  return first;
}
 
開發者ID:skaringa,項目名稱:tzdataservice,代碼行數:10,代碼來源:TzDataShpFileReadAndLocate.java

示例12: getWMSOutcomeTest

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test(enabled = true, groups = { "suitability", "integration" })
  public void getWMSOutcomeTest() throws Exception {
    LOGGER.debug("getWMSOutcomeTest");
    // TODO Sometimes analysis of the whole area studies necessary,bbetter create a different test altogether  and disable it?
//    String areaAnalyzed = WifKeys.POLYGON_TEST;
     String areaAnalyzed = null;
    String crsArea = WifKeys.CRS_TEST;

    Boolean wmsOutcome = suitabilityScenarioService.getWMSOutcome(
        WifKeys.TEST_SUITABILITY_SCENARIO_ID, areaAnalyzed, crsArea);
    Assert.assertEquals(wmsOutcome, Boolean.TRUE);

    Map<String, Object> wifParameters = new HashMap<String, Object>();
    wifParameters.put(WifKeys.POLYGON, WifKeys.POLYGON_TEST);
    wifParameters.put(WifKeys.CRS_ORG, WifKeys.CRS_TEST);
    wifParameters.put(WifKeys.CRS_DEST, WifKeys.CRS_TEST);
    Filter filter = geodataFilterer.getFilterFromParameters(wifParameters);
    SimpleFeatureCollection uazCollection = geodataFinder
        .getFeatureCollectionfromDB("uaz_demonstration", filter);
    SimpleFeatureIterator it = uazCollection.features();
    Double score = 0.0;
    try {
      while (it.hasNext()) {
        SimpleFeature uazFeature = it.next();
        if (uazFeature.getID().equals("uaz_demonstration.730")) {

          score = (Double) uazFeature.getAttribute("SCORE_1");
        }
      }
    } finally {
      it.close();
    }
    // TODO this is the value when the polygon test is enforced
    Assert.assertEquals(score, new Double(10000.0));
    // TODO this is the value when the wwhole areatest is enforced
    // Assert.assertEquals((Double) score, new Double(8125.0));
  }
 
開發者ID:AURIN,項目名稱:online-whatif,代碼行數:38,代碼來源:SuitabilityDBOutcomeIT.java

示例13: testGetFeaturesWithNOTLogicFilter

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
@Test
public void testGetFeaturesWithNOTLogicFilter() throws Exception {
    init();
    FilterFactory ff = dataStore.getFilterFactory();
    PropertyIsEqualTo property1 = ff.equals(ff.property("vendor_s"), ff.literal("D-Link"));
    Not filter = ff.not(property1);
    SimpleFeatureCollection features = featureSource.getFeatures(filter);
    assertEquals(7, features.size());
    SimpleFeatureIterator iterator = features.features();
    while (iterator.hasNext()) {
        SimpleFeature f = iterator.next();
        assertTrue(!f.getAttribute("vendor_s").equals("D-Link"));
    }
}
 
開發者ID:ngageoint,項目名稱:elasticgeo,代碼行數:15,代碼來源:ElasticFeatureFilterIT.java

示例14: load

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
public void load (ShapeDataStore store) throws Exception {
    FileDataStore fds = FileDataStoreFinder.getDataStore(shapefile);
    SimpleFeatureSource src = fds.getFeatureSource();

    Query q = new Query();
    q.setCoordinateSystem(src.getInfo().getCRS());
    q.setCoordinateSystemReproject(CRS.decode("EPSG:4326", true));
    SimpleFeatureCollection sfc = src.getFeatures(q);

    for (SimpleFeatureIterator it = sfc.features(); it.hasNext();) {
        GeobufFeature feat = new GeobufFeature(it.next());
        feat.id = null;
        feat.numericId = Long.parseLong((String) feat.properties.get("GEOID10"));
        feat.properties = new HashMap<>();
        store.add(feat);
    }
}
 
開發者ID:conveyal,項目名稱:seamless-census,代碼行數:18,代碼來源:TigerLineSource.java

示例15: readShapes

import org.geotools.data.simple.SimpleFeatureCollection; //導入方法依賴的package包/類
public void readShapes(final IScope scope) {
	final IList<IShape> list = getBuffer();
	int size = 0;
	final SimpleFeatureCollection fc = getFeatureCollection(scope);
	if (fc == null)
		return;
	final Envelope3D env = Envelope3D.of(fc.getBounds());
	size = fc.size();
	int index = 0;
	computeProjection(scope, env);
	try (SimpleFeatureIterator reader = fc.features()) {
		while (reader.hasNext()) {
			index++;
			if (index % 20 == 0)
				scope.getGui().getStatus(scope).setSubStatusCompletion(index / size);
			final SimpleFeature feature = reader.next();
			Geometry g = (Geometry) feature.getDefaultGeometry();
			if (g != null && !g.isEmpty() /* Fix for Issue 725 && 677 */ ) {
				g = gis.transform(g);
				if (!with3D) {
					g.apply(ZERO_Z);
					g.geometryChanged();
				}
				list.add(new GamaGisGeometry(g, feature));
			} else if (g == null) {
				// See Issue 725
				GAMA.reportError(scope,
						GamaRuntimeException
								.warning("GamaGeoJsonFile.fillBuffer; geometry could not be added  as it is "
										+ "nil: " + feature.getIdentifier(), scope),
						false);
			}
		}
	}
	if (size > list.size()) {
		GAMA.reportError(scope, GamaRuntimeException.warning("Problem with file " + getFile(scope) + ": only "
				+ list.size() + " of the " + size + " geometries could be added", scope), false);
	}
}
 
開發者ID:gama-platform,項目名稱:gama,代碼行數:40,代碼來源:GamaGeoJsonFile.java


注:本文中的org.geotools.data.simple.SimpleFeatureCollection.features方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。