本文整理汇总了Java中com.vividsolutions.jts.operation.polygonize.Polygonizer类的典型用法代码示例。如果您正苦于以下问题:Java Polygonizer类的具体用法?Java Polygonizer怎么用?Java Polygonizer使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
Polygonizer类属于com.vividsolutions.jts.operation.polygonize包,在下文中一共展示了Polygonizer类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: splitPolygon
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
/**
* {@link Polygon} by {@link LineString} split.
*
* <p>From JTS ml: http://lists.refractions.net/pipermail/jts-devel/2008-September/002666.html</p>
*
* @param polygon the input polygon.
* @param line the input line to use to split.
* @return the list of split polygons.
*/
public static List<Polygon> splitPolygon( Polygon polygon, LineString line ) {
/*
* Use MCIndexNoder to node the polygon and linestring together,
* Polygonizer to polygonize the noded edges, and then PointLocater
* to determine which of the resultant polygons correspond to
* the input polygon.
*/
IntersectionAdder _intersector = new IntersectionAdder(new RobustLineIntersector());
MCIndexNoder mci = new MCIndexNoder();
mci.setSegmentIntersector(_intersector);
NodedSegmentString pSeg = new NodedSegmentString(polygon.getCoordinates(), null);
NodedSegmentString lSeg = new NodedSegmentString(line.getCoordinates(), null);
List<NodedSegmentString> nodesSegmentStringList = new ArrayList<NodedSegmentString>();
nodesSegmentStringList.add(pSeg);
nodesSegmentStringList.add(lSeg);
mci.computeNodes(nodesSegmentStringList);
Polygonizer polygonizer = new Polygonizer();
List<LineString> lsList = new ArrayList<LineString>();
for( Object o : mci.getMonotoneChains() ) {
MonotoneChain mtc = (MonotoneChain) o;
LineString l = gf().createLineString(mtc.getCoordinates());
lsList.add(l);
}
Geometry nodedLineStrings = lsList.get(0);
for( int i = 1; i < lsList.size(); i++ ) {
nodedLineStrings = nodedLineStrings.union(lsList.get(i));
}
polygonizer.add(nodedLineStrings);
@SuppressWarnings("unchecked")
Collection<Polygon> polygons = polygonizer.getPolygons();
List<Polygon> newPolygons = new ArrayList<Polygon>();
PointLocator pl = new PointLocator();
for( Polygon p : polygons ) {
if (pl.locate(p.getInteriorPoint().getCoordinate(), p) == Location.INTERIOR) {
newPolygons.add(p);
}
}
return newPolygons;
}
示例2: run
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
void run()
throws Exception {
WKTReader rdr = new WKTReader();
Collection lines = new ArrayList();
lines.add(rdr.read("LINESTRING (0 0 , 10 10)")); // isolated edge
lines.add(rdr.read("LINESTRING (185 221, 100 100)")); //dangling edge
lines.add(rdr.read("LINESTRING (185 221, 88 275, 180 316)"));
lines.add(rdr.read("LINESTRING (185 221, 292 281, 180 316)"));
lines.add(rdr.read("LINESTRING (189 98, 83 187, 185 221)"));
lines.add(rdr.read("LINESTRING (189 98, 325 168, 185 221)"));
Polygonizer polygonizer = new Polygonizer();
polygonizer.add(lines);
Collection polys = polygonizer.getPolygons();
System.out.println("Polygons formed (" + polys.size() + "):");
System.out.println(polys);
}
示例3: execute
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
public void execute(Scope scope)
throws Exception
{
Polygonizer polygonizer = new Polygonizer();
int geomIndex = SchemaUtil.getColumnWithType(inputLines.getRows().getSchema(), Geometry.class);
//TODO: handle no geometry case (return empty table)
RowIterator i = inputLines.getRows().iterator();
while (true) {
Row row = i.next();
if (row == null)
break;
Geometry g = (Geometry) row.getValue(geomIndex);
polygonizer.add(g);
}
Collection polys = polygonizer.getPolygons();
result = createGeometryTable(polys);
}
示例4: PolygonBuilder
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
public PolygonBuilder(Collection<Geometry> inputs) {
this.polygen = new Polygonizer();
// Inputs that are incorrectly noded or may have duplicate geometry
// can cause the polygonizer to fail. Since polygonization is often
// at the end of a long process, the price of UnaryUnionOp.Union()
// is well worth it.
//this.polygen.add(inputs);
this.polygen.add(UnaryUnionOp.union(inputs));
}
示例5: polygonize
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
public static Geometry polygonize(Geometry geom) {
List lines = LineStringExtracter.getLines(geom);
Polygonizer polygonizer = new Polygonizer();
polygonizer.add(lines);
return geom.getFactory().buildGeometry(polygonizer.getPolygons());
}
示例6: cutOnPoles
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
/**
* Cut given polygon on poles (89 and -89)
*/
private static String cutOnPoles(String polygonWKT) throws Exception
{
JtsSpatialContextFactory noCheckFactory = new JtsSpatialContextFactory();
noCheckFactory.datelineRule = DatelineRule.none;
noCheckFactory.validationRule = ValidationRule.none;
JtsSpatialContext noCheckContext = noCheckFactory.newSpatialContext();
JtsWKTReaderShapeParser noCheckParser =
new JtsWKTReaderShapeParser(noCheckContext, noCheckFactory);
JtsGeometry polygon = (JtsGeometry) noCheckParser.parse(polygonWKT);
JtsGeometry northPole =
(JtsGeometry) noCheckParser.parse("LINESTRING(180 89, 0 89, -180 89)");
JtsGeometry southPole =
(JtsGeometry) noCheckParser.parse("LINESTRING(180 -89, 0 -89, -180 -89)");
LineMerger lm = new LineMerger();
lm.add(polygon.getGeom());
lm.add(northPole.getGeom());
lm.add(southPole.getGeom());
Geometry geometry = UnaryUnionOp.union(lm.getMergedLineStrings());
Polygonizer polygonizer = new Polygonizer();
polygonizer.add(geometry);
List<Polygon> foundPolygons = (List<Polygon>) polygonizer.getPolygons();
List<Polygon> filteredPolygons = new ArrayList<>();
for (Polygon p: foundPolygons)
{
// removing polygons over the poles
if (p.getCentroid().getCoordinate().y < 89 && p.getCentroid().getCoordinate().y > -89)
{
filteredPolygons.add(p);
}
}
Geometry res = null;
if (!filteredPolygons.isEmpty())
{
res = filteredPolygons.get(0);
}
if (filteredPolygons.size() > 1)
{
// Should not happen...
LOGGER.error("A Multipolygon was found, instead of a single polygon. Only the first one is retained.");
}
WKTWriter wkw = new WKTWriter();
return wkw.write(res);
}
示例7: process
import com.vividsolutions.jts.operation.polygonize.Polygonizer; //导入依赖的package包/类
@Execute
public void process() throws Exception {
checkNull(inMap);
outMap = new DefaultFeatureCollection();
EGeometryType geometryType = EGeometryType.forGeometryDescriptor(inMap.getSchema().getGeometryDescriptor());
switch( geometryType ) {
case LINE:
case MULTILINE:
break;
default:
throw new ModelsIllegalargumentException("The module only works with line layers.", this, pm);
}
List<Geometry> linesList = FeatureUtilities.featureCollectionToGeometriesList(inMap, true, null);
// Polygonization
final Polygonizer polygonizer = new Polygonizer();
polygonizer.add(linesList);
@SuppressWarnings("unchecked")
final Collection<Polygon> polygonizedLines = polygonizer.getPolygons();
SimpleFeatureTypeBuilder b = new SimpleFeatureTypeBuilder();
b.setName("polygonized");
b.setCRS(inMap.getSchema().getCoordinateReferenceSystem());
b.add("the_geom", Polygon.class);
b.add(fNewId, String.class);
SimpleFeatureType type = b.buildFeatureType();
SimpleFeatureBuilder builder = new SimpleFeatureBuilder(type);
List<Geometry> pointGeometries = new ArrayList<Geometry>();
if (inPoints != null) {
fId = FeatureUtilities.findAttributeName(inPoints.getSchema(), fId);
pointGeometries = FeatureUtilities.featureCollectionToGeometriesList(inPoints, false, fId);
}
pm.beginTask("Generating polygon features...", polygonizedLines.size());
int index = 0;
for( Polygon polygon : polygonizedLines ) {
String attribute = String.valueOf(index++);
if (inPoints != null) {
attribute = "-";
for( Geometry point : pointGeometries ) {
if (polygon.contains(point)) {
attribute = point.getUserData().toString();
break;
}
}
}
Object[] values = new Object[]{polygon, attribute};
builder.addAll(values);
SimpleFeature feature = builder.buildFeature(null);
((DefaultFeatureCollection) outMap).add(feature);
pm.worked(1);
}
pm.done();
}