public static Geometry jtsToGo1(
final com.vividsolutions.jts.geom.Geometry jtsGeom,
final CoordinateReferenceSystem crs) {
Hints hints = new Hints( Hints.CRS, crs );
PrimitiveFactory pf = GeometryFactoryFinder.getPrimitiveFactory(hints);
GeometryFactory gf = GeometryFactoryFinder.getGeometryFactory(hints);
String geomType = jtsGeom.getGeometryType();
if (geomType.equalsIgnoreCase("Point")) {
com.vividsolutions.jts.geom.Point jtsPoint =
(com.vividsolutions.jts.geom.Point) jtsGeom;
DirectPosition dp = pointToDirectPosition(jtsPoint, crs);
Point result = pf.createPoint(dp);
return result;
} else if (geomType.equalsIgnoreCase("LineString")) {
com.vividsolutions.jts.geom.LineString jtsLineString =
(com.vividsolutions.jts.geom.LineString) jtsGeom;
int numPoints = jtsLineString.getNumPoints();
LineString ls = gf.createLineString(new ArrayList());
List pointList = ls.getControlPoints();
for (int i=0; i<numPoints; i++) {
pointList.add(coordinateToDirectPosition(jtsLineString.getCoordinateN(i), crs));
}
ArrayList segments = new ArrayList();
segments.add(ls);
Curve result = pf.createCurve(segments);
return result;
} else if (geomType.equalsIgnoreCase("LinearRing")) {
Ring result = linearRingToRing(
(com.vividsolutions.jts.geom.LinearRing) jtsGeom, crs);
return result;
} else if (geomType.equalsIgnoreCase("Polygon")) {
com.vividsolutions.jts.geom.Polygon jtsPolygon =
(com.vividsolutions.jts.geom.Polygon) jtsGeom;
Ring externalRing = linearRingToRing(
(com.vividsolutions.jts.geom.LinearRing) jtsPolygon.getExteriorRing(),
crs);
int n = jtsPolygon.getNumInteriorRing();
ArrayList internalRings = new ArrayList();
for (int i=0; i<n; i++) {
internalRings.add(linearRingToRing(
(com.vividsolutions.jts.geom.LinearRing) jtsPolygon.getInteriorRingN(i),
crs));
}
SurfaceBoundary boundary = pf.createSurfaceBoundary(externalRing,
internalRings);
Polygon polygon = gf.createPolygon(boundary);
ArrayList patches = new ArrayList();
patches.add(polygon);
PolyhedralSurface result = gf.createPolyhedralSurface(patches);