本文整理匯總了Java中org.opengis.feature.simple.SimpleFeature.getDefaultGeometry方法的典型用法代碼示例。如果您正苦於以下問題:Java SimpleFeature.getDefaultGeometry方法的具體用法?Java SimpleFeature.getDefaultGeometry怎麽用?Java SimpleFeature.getDefaultGeometry使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.opengis.feature.simple.SimpleFeature
的用法示例。
在下文中一共展示了SimpleFeature.getDefaultGeometry方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: correctFeatures
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的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;
}
示例2: testCorrect3857Transform
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
/**
* tests a coordinate transformation from epsg:4236 --> epsg:3857
*/
@Test
public void testCorrect3857Transform() {
algo.setTargetEPSG("EPSG:3857");
try {
algo.runAlgorithm();
FeatureCollection fc = algo.getResult();
FeatureIterator<?> featureIterator = fc.features();
SimpleFeature feature = (SimpleFeature) featureIterator.next();
Geometry geometry = (Geometry) feature.getDefaultGeometry();
Coordinate[] coords = geometry.getCoordinates();
assertEquals(5781631.60732, coords[0].x, 0.001);
assertEquals(1002058.9016, coords[0].y, 0.001);
assertEquals(5364555.78035, coords[1].x, 0.001);
assertEquals(908752.762799, coords[1].y, 0.001);
assertEquals(5810127.070382, coords[2].x, 0.001);
assertEquals(883747.339307, coords[2].y, 0.001);
assertEquals(5770326.33379, coords[3].x, 0.001);
assertEquals(861269.968343, coords[3].y, 0.001);
assertEquals(5581093.09574, coords[4].x, 0.001);
assertEquals(772727.762141, coords[4].y, 0.001);
} catch (Exception e) {
fail("Exception thrown: " + e.getMessage());
}
}
示例3: CommunityAreas
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public CommunityAreas() {
communities = new HashMap<>();
try {
File f = new File(shapeFilePath);
ShapefileDataStore shapefile = new ShapefileDataStore(f.toURI().toURL());
SimpleFeatureIterator features = shapefile.getFeatureSource().getFeatures().features();
SimpleFeature shp;
while (features.hasNext()) {
shp = features.next();
int id = Integer.parseInt((String) shp.getAttribute("AREA_NUMBE"));
String name = (String) shp.getAttribute("COMMUNITY");
MultiPolygon boundary = (MultiPolygon) shp.getDefaultGeometry();
CommunityArea ca = new CommunityArea(id, name, boundary);
communities.put(id, ca);
}
features.close();
shapefile.dispose();
} catch (IOException e) {
e.printStackTrace();
}
}
示例4: Tracts
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public Tracts() {
tracts = new HashMap<>();
try {
SimpleFeatureIterator features = getShapeFileFeatures();
SimpleFeature shp;
while (features.hasNext()) {
shp = features.next();
int id = Integer.parseInt((String) shp.getAttribute("tractce10"));
MultiPolygon boundary = (MultiPolygon) shp.getDefaultGeometry();
Tract t = new Tract(id, boundary);
tracts.put(id, t);
}
features.close();
shapefile.dispose();
} catch (IOException e) {
e.printStackTrace();
}
}
示例5: testAllShapesArePolygon
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public void testAllShapesArePolygon() {
try {
SimpleFeatureIterator features = Tracts.getShapeFileFeatures();
SimpleFeature shp = features.next();
int fieldSize = shp.getType().getTypes().size();
assertEquals(fieldSize, 10);
assertEquals(shp.getType().getType(3).getName().getLocalPart(), "tractce10");
assertEquals(shp.getType().getType(0).getName().getLocalPart(), "MultiPolygon");
for (int i = 0; i < fieldSize; i++){
System.out.println(shp.getType().getType(i).getName().getLocalPart());
}
int cnt = 1;
while (features.hasNext()) {
shp = features.next();
MultiPolygon g = (MultiPolygon) shp.getDefaultGeometry();
cnt ++;
}
assertEquals(cnt, 801);
features.close();
Tracts.shapefile.dispose();
} catch (IOException e) {
e.printStackTrace();
}
}
示例6: fromSimpleFeature
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public static GeoInfo fromSimpleFeature(SimpleFeature feature) {
GeoInfo that = new GeoInfo();
for (Property p: feature.getProperties()) {
if (p.getName().toString().equals("NAME"))
that.name = p.getValue().toString();
if (p.getName().toString().equals("STATE"))
that.state = p.getValue().toString();
if (p.getName().toString().equals("COUNTY"))
that.county = p.getValue().toString();
if (p.getName().toString().equals("CITY"))
that.city = p.getValue().toString();
}
that.multiPolygon = (MultiPolygon) feature.getDefaultGeometry();
return that;
}
示例7: getValueAt
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
@Override
public Object getValueAt(int row, int column) {
if ((row < 0) || (row >= getRowCount())) {
return null;
}
if ((column < 0) || (column >= getColumnCount())) {
return null;
}
SimpleFeature feature = getFeature(row);
if (feature != null) {
if (column == geometryFieldIndex) {
Object defaultGeometry = feature.getDefaultGeometry();
return defaultGeometry;
} else {
Object attributeData = feature.getAttribute(column);
return attributeData;
}
}
return null;
}
示例8: joinFeaures
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的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;
}
示例9: exportToShapefile
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
/**
* Export features to a new shapefile using the map projection in which
* they are currently displayed
*/
public static void exportToShapefile(DataStore newDataStore, FeatureCollection<SimpleFeatureType,SimpleFeature> featureCollection)/*,SimpleFeatureType ftype)*/ throws Exception {
// carefully open an iterator and writer to process the results
Transaction transaction = new DefaultTransaction();
FeatureWriter<SimpleFeatureType, SimpleFeature> writer = newDataStore.getFeatureWriter(newDataStore.getTypeNames()[0], transaction);
FeatureIterator<SimpleFeature> iterator = featureCollection.features();
try {
while( iterator.hasNext() ){
SimpleFeature feature = iterator.next();
SimpleFeature copy = writer.next();
//copy.setAttributes( feature.getAttributes() );
Geometry geometry = (Geometry) feature.getDefaultGeometry();
if(geometry!=null){
copy.setDefaultGeometry( geometry.buffer(0));
writer.write();
}else{
logger.warn("Warning:geometry null");
}
}
transaction.commit();
logger.info("Export to shapefile complete" );
} catch (Exception problem) {
problem.printStackTrace();
transaction.rollback();
logger.error("Export to shapefile failed",problem );
} finally {
writer.close();
iterator.close();
transaction.close();
}
}
示例10: testCorrect4817Transform
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
/**
* tests a coordinate transformation from epsg:4236 --> epsg:4817
*/
@Test
public void testCorrect4817Transform() {
algo.setTargetEPSG("EPSG:4817");
try {
algo.runAlgorithm();
FeatureCollection fc = algo.getResult();
FeatureIterator<?> featureIterator = fc.features();
SimpleFeature feature = (SimpleFeature) featureIterator.next();
Geometry geometry = (Geometry) feature.getDefaultGeometry();
Coordinate[] coords = geometry.getCoordinates();
assertEquals(41.2178843506, coords[0].x, 0.001);
assertEquals(8.95903973526, coords[0].y, 0.001);
assertEquals(37.4710724824, coords[1].x, 0.001);
assertEquals(8.13026146044, coords[1].y, 0.001);
assertEquals(41.473842952, coords[2].x, 0.001);
assertEquals(7.90771407361, coords[2].y, 0.001);
assertEquals(41.1162889713, coords[3].x, 0.001);
assertEquals(7.70767521468, coords[3].y, 0.001);
assertEquals(39.4162959551, coords[4].x, 0.001);
assertEquals(6.91879868251, coords[4].y, 0.001);
FeatureCollection result = algo.getResult();
} catch (Exception e) {
fail("Exception thrown: " + e.getMessage());
}
}
示例11: getTimeZone
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
private String getTimeZone(double lat, double lon){
Point point = geometryFactory.createPoint(new Coordinate(lon,lat));
List<Object> regions = quadtree.query(point.getEnvelopeInternal());
for(Object o : regions){
SimpleFeature feature = (SimpleFeature) o;
Geometry geom = (Geometry) feature.getDefaultGeometry();
if(point.within(geom)) {
return (String)(feature.getAttribute("TZID"));
}
}
throwError(BAD_REQUEST.getStatusCode(),"could not localize location " + lat + ", " + lon);
return null;
}
示例12: testAllShapesArePolygon
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public void testAllShapesArePolygon() {
try {
File fin = new File(CommunityAreas.shapeFilePath);
ShapefileDataStore r = new ShapefileDataStore(fin.toURI().toURL());
SimpleFeatureType sft = r.getSchema();
assertEquals(sft.getTypes().size(), 10);
assertEquals(sft.getType(0).getName().getLocalPart(), "MultiPolygon");
assertEquals(sft.getType(5).getName().getLocalPart(), "AREA_NUMBE");
assertEquals(sft.getType(6).getName().getLocalPart(), "COMMUNITY");
FeatureReader<SimpleFeatureType, SimpleFeature> fr = r.getFeatureReader();
SimpleFeature shp;
int total = 0;
while (fr.hasNext()) {
total ++;
shp = fr.next();
MultiPolygon g = (MultiPolygon) shp.getDefaultGeometry();
}
fr.close();
r.dispose();
assertEquals(total, 77);
} catch (Exception e) {
e.printStackTrace();
}
}
示例13: extractNormalizedGeometry
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
private Optional<Geometry> extractNormalizedGeometry(SimpleFeature feature, MathTransform crsTransform) throws TransformException {
try {
Geometry geom = (Geometry) feature.getDefaultGeometry();
Geometry transformedGeom = JTS.transform(geom, crsTransform);
transformedGeom.setSRID(Subject.SRID);
return Optional.of(transformedGeom);
} catch (ProjectionException e) {
log.warn("Rejecting feature {}. You will see this if you have assertions enabled (e.g. " +
"you run with `-ea`) as GeoTools runs asserts. See source of GeotoolsDataStoreUtils for details on this. " +
"To fix this, replace `-ea` with `-ea -da:org.geotools...` in your test VM options (probably in" +
"your IDE) to disable assertions in GeoTools.", feature.getID());
return Optional.empty();
}
}
開發者ID:FutureCitiesCatapult,項目名稱:TomboloDigitalConnector,代碼行數:15,代碼來源:AbstractGeotoolsDataStoreImporter.java
示例14: updateFeature
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
public static void updateFeature(SimpleFeature feature) {
Point point = (Point) feature.getDefaultGeometry();
Double step = (Double) feature.getAttribute("step");
Double newLong = nudgeLong(point.getX() + step);
Geometry newPoint = WKTUtils$.MODULE$.read("POINT(" + newLong + " " + point.getY() + ")");
feature.setAttribute("dtg", new Date());
feature.setDefaultGeometry(newPoint);
}
示例15: prepareOperations
import org.opengis.feature.simple.SimpleFeature; //導入方法依賴的package包/類
/**
* Filters operations and triggers the analysis
*/
private void prepareOperations(List<IVgiFeature> batch) {
for (IVgiFeature feature : batch) {
/** Filter by tag */
if (!feature.filterByTag(settings.getFilterTag())) continue;
if (settings.getCurrentPolygon() != null || settings.isWriteGeometryFiles()) {
if (settings.getCurrentPolygon() != null) {
if (!settings.getCurrentPolygon().getPolygon().getEnvelopeInternal().intersects(feature.getBBox())) continue;
}
SimpleFeature f = geometryAssemblerConsumer.assembleGeometry(feature, null);
if (f == null) continue;
if (((Geometry)f.getDefaultGeometry()).getGeometryType().equals("LineString")) {
double length = GeomUtils.calculateLengthMeterFromWGS84LineStringAndoyer((LineString)f.getDefaultGeometry());
f.setAttribute("length", length);
}
if (settings.getCurrentPolygon() != null) {
Geometry geometry = (Geometry)f.getDefaultGeometry();
if (geometry == null || geometry.disjoint(settings.getCurrentPolygon().getPolygon())) continue;
}
if (settings.isWriteGeometryFiles()) {
if (!mapFeatures.containsKey(f.getFeatureType())) mapFeatures.put(f.getFeatureType(), new DefaultFeatureCollection(f.getFeatureType().getTypeName(), f.getFeatureType()));
if (!(boolean)f.getAttribute("deleted")) {
mapFeatures.get(f.getFeatureType()).add(f);
}
}
}
featureList.add(feature);
}
analyzeFeatures();
}