use of org.opengis.geometry.coordinate.LineString in project geotoolkit by Geomatys.
the class GeometryUtils method getDirectPositions.
public static DirectPosition[] getDirectPositions(final Ring ring) {
final List directPositionList = new ArrayList();
// Cast below can be removed when Types will be allowed to abandon Java 1.4 support.
final List /*<Curve>*/
generators = (List) ring.getGenerators();
for (int i = 0; i < generators.size(); i++) {
final Curve curve = (Curve) generators.get(i);
final List /*<CurveSegments>*/
segments = curve.getSegments();
for (int j = 0; j < segments.size(); j++) {
final CurveSegment curveSegment = (CurveSegment) segments.get(j);
if (curveSegment instanceof LineString) {
final LineString lineString = (LineString) curveSegment;
final DirectPosition[] positions = getDirectPositions(lineString);
directPositionList.addAll(Arrays.asList(positions));
/*final List<Position> positions = lineString.getControlPoints().positions();
for (int k = 0; k < positions.size(); k++) {
Position position = (Position) positions.get(k);
directPositionList.add(position.getPosition());
}*/
}
}
}
if (directPositionList.size() > 0) {
return (DirectPosition[]) directPositionList.toArray(new DirectPosition[directPositionList.size()]);
}
return new DirectPosition[0];
}
use of org.opengis.geometry.coordinate.LineString in project geotoolkit by Geomatys.
the class JTSUtils method linearRingToRing.
public static Ring linearRingToRing(final org.locationtech.jts.geom.LineString jtsLinearRing, final CoordinateReferenceSystem crs) {
int numPoints = jtsLinearRing.getNumPoints();
if (numPoints != 0 && !jtsLinearRing.getCoordinateN(0).equals(jtsLinearRing.getCoordinateN(numPoints - 1))) {
throw new IllegalArgumentException("LineString must be a ring");
}
// FactoryFinder.getPrimitiveFactory(hints);
PrimitiveFactory pf = new JTSPrimitiveFactory(crs);
// FactoryFinder.getGeometryFactory(hints);
GeometryFactory gf = new JTSGeometryFactory(crs);
LineString ls = gf.createLineString(new ArrayList());
List pointList = ls.getControlPoints();
for (int i = 0; i < numPoints; i++) {
pointList.add(coordinateToDirectPosition(jtsLinearRing.getCoordinateN(i), crs));
}
Curve curve = pf.createCurve(new ArrayList());
// Cast below can be removed when Types will be allowed to abandon Java 1.4 support.
((List) curve.getSegments()).add(ls);
Ring result = pf.createRing(new ArrayList());
// Cast below can be removed when Types will be allowed to abandon Java 1.4 support.
((List) result.getGenerators()).add(curve);
return result;
}
use of org.opengis.geometry.coordinate.LineString in project geotoolkit by Geomatys.
the class JTSGeometryFactory method createLineString.
/**
* {@inheritDoc }
*/
@Override
public LineString createLineString(final List points) {
LineString result = new JTSLineString(crs);
PointArray pa = result.getControlPoints();
List list = pa;
Iterator it = points.iterator();
while (it.hasNext()) {
// Object o = it.next();
// if (o instanceof DirectPosition) {
// list.add(o);
// } else if (o instanceof Position) {
// Position p = (Position) o;
// DirectPosition dp = p.getPosition();
// /*if (dp == null) {
// dp = p.getIndirect().getPosition();
// }*/
// list.add(dp);
// }
Position position = (Position) it.next();
DirectPosition directPosition = position.getDirectPosition();
list.add(directPosition);
}
return result;
}
Aggregations