/** * Creates a new polygon. * * @param dimension Dimension of the polygon * @param srid SRID values * @param interior List of interior points * @param exterior List of exterior point * @deprecated */ public Polygon(final Dimension dimension, final SRID srid, final List<Point> interior, final List<Point> exterior) { super(dimension, Type.POLYGON, srid); if (interior != null) { LineString lineString = new LineString(dimension, srid, interior); this.interiorRings = new MultiLineString(dimension, srid, Arrays.asList(lineString)); } else { this.interiorRings = null; } this.exterior = new LineString(dimension, srid, exterior); }
private LineString lineString(final Iterator<JsonNode> itor, final EdmPrimitiveTypeKind type, final SRID srid) { final LineString lineString; if (itor.hasNext()) { final List<Point> points = new ArrayList<Point>(); while (itor.hasNext()) { final Iterator<JsonNode> mpItor = itor.next().elements(); points.add(point(mpItor, type, srid)); } lineString = new LineString(GeoUtils.getDimension(type), srid, points); } else { lineString = new LineString(GeoUtils.getDimension(type), srid, Collections.<Point> emptyList()); } return lineString; }
private LineString lineString(final Iterator<JsonNode> itor, final EdmPrimitiveTypeKind type, final SRID srid) { final LineString lineString; if (itor.hasNext()) { final List<Point> points = new ArrayList<Point>(); while (itor.hasNext()) { final Iterator<JsonNode> mpItor = itor.next().elements(); points.add(point(mpItor, type, srid)); } lineString = new LineString(GeoUtils.getDimension(type), srid, points); } else { lineString = new LineString(GeoUtils.getDimension(type), srid, Collections.<Point> emptyList()); } return lineString; }
private LineString newLineString(final SRID srid, final String lineString, final Boolean isNullable, final Integer maxLength, final Integer precision, final Integer scale, final Boolean isUnicode) throws EdmPrimitiveTypeException { final List<Point> points = new ArrayList<Point>(); for (final String pointCoo : split(lineString, ',')) { points.add(newPoint(null, pointCoo, isNullable, maxLength, precision, scale, isUnicode)); } return new LineString(this.dimension, srid, points); }
private LineString newLineString(final SRID srid, final String lineString, final Boolean isNullable, final Integer maxLength, final Integer precision, final Integer scale, final Boolean isUnicode) throws EdmPrimitiveTypeException { final List<Point> points = new ArrayList<Point>(); for (final String pointCoo : split(lineString, ',')) { points.add(newPoint(null, pointCoo, isNullable, maxLength, precision, scale, isUnicode)); } return new LineString(this.dimension, srid, points); }
private Polygon newPolygon(final SRID srid, final String polygon, final Boolean isNullable, final Integer maxLength, final Integer precision, final Integer scale, final Boolean isUnicode) throws EdmPrimitiveTypeException { final String[] first = polygon.split("\\),\\("); final List<LineString> interiorRings = new ArrayList<LineString>(); for (int i = 0; i < first.length -1; i++) { List<Point> interior = new ArrayList<Point>(); for (final String pointCoo : split(first[i].substring(i==0?1:0, first[i].length()), ',')) { interior.add(newPoint(null, pointCoo, isNullable, maxLength, precision, scale, isUnicode)); } interiorRings.add(new LineString(dimension, srid, interior)); } final List<Point> exterior = new ArrayList<Point>(); for (final String pointCoo : split(first[first.length -1].substring(0, first[first.length -1].length() - 1), ',')) { exterior.add(newPoint(null, pointCoo, isNullable, maxLength, precision, scale, isUnicode)); } return new Polygon(dimension, srid, interiorRings, new LineString(dimension, srid, exterior)); }
private LineString lineString(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { return new LineString(GeoUtils.getDimension(type), srid, points(reader, start, type, null)); }
private LineString lineString(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { return new LineString(GeoUtils.getDimension(type), srid, points(reader, start, type, null)); }
private Polygon polygon(final XMLEventReader reader, final StartElement start, final EdmPrimitiveTypeKind type, final SRID srid) throws XMLStreamException { LineString extPoints = null; List<LineString> intRings = new ArrayList<LineString>(); boolean foundEndProperty = false; while (reader.hasNext() && !foundEndProperty) { final XMLEvent event = reader.nextEvent(); if (event.isStartElement()) { if (event.asStartElement().getName().equals(Constants.QNAME_POLYGON_EXTERIOR)) { List<Point> points = points(reader, event.asStartElement(), type, null); extPoints = new LineString(GeoUtils.getDimension(type), srid, points); } if (event.asStartElement().getName().equals(Constants.QNAME_POLYGON_INTERIOR)) { List<Point> points = points(reader, event.asStartElement(), type, null); intRings.add(new LineString(GeoUtils.getDimension(type), srid, points)); } } if (event.isEndElement() && start.getName().equals(event.asEndElement().getName())) { foundEndProperty = true; } } return new Polygon(GeoUtils.getDimension(type), srid, intRings, extPoints); }
private Polygon polygon(final Iterator<JsonNode> itor, final EdmPrimitiveTypeKind type, final SRID srid) { List<Point> extPoints = null; if (itor.hasNext()) { final Iterator<JsonNode> extItor = itor.next().elements(); if (extItor.hasNext()) { extPoints = new ArrayList<Point>(); while (extItor.hasNext()) { final Iterator<JsonNode> mpItor = extItor.next().elements(); extPoints.add(point(mpItor, type, srid)); } } } List<LineString> intRings = new ArrayList<LineString>(); while (itor.hasNext()) { final Iterator<JsonNode> intItor = itor.next().elements(); if (intItor.hasNext()) { List<Point> intPoints = new ArrayList<Point>(); while (intItor.hasNext()) { final Iterator<JsonNode> mpItor = intItor.next().elements(); intPoints.add(point(mpItor, type, srid)); } intRings.add(new LineString(GeoUtils.getDimension(type), srid, intPoints)); } } LineString exterior = new LineString(GeoUtils.getDimension(type), srid, extPoints); return new Polygon(GeoUtils.getDimension(type), srid, intRings, exterior); }
return new LineString(dimension, null, readGeoPointValues(name, dimension, 0, false, topNode)); } else if (geoDataType.equals(MultiLineString.class)) { List<LineString> lines = new ArrayList<LineString>(); for (final JsonNode element : topNode) { lines.add(new LineString(dimension, null, readGeoPointValues(name, dimension, 0, false, element)));
return new LineString(dimension, srid, readGeoPointValues(name, dimension, 0, false, topNode)); } else if (geoDataType.equals(MultiLineString.class)) { List<LineString> lines = new ArrayList<LineString>(); for (final JsonNode element : topNode) { lines.add(new LineString(dimension, srid, readGeoPointValues(name, dimension, 0, false, element)));
LineString lineString = (LineString) geometry; ArrayList<org.apache.olingo.commons.api.edm.geo.Point> points = convertLineStringToPoints(lineString.getCoordinates()); org.apache.olingo.commons.api.edm.geo.LineString result = new org.apache.olingo.commons.api.edm.geo.LineString(dimension, srid, points); return result; } else if (geometry instanceof Polygon) { for (int i = 0; i < multiLineString.getNumGeometries(); i++) { LineString lineString = (LineString)multiLineString.getGeometryN(i); lineStrings.add(new org.apache.olingo.commons.api.edm.geo.LineString(dimension, srid, convertLineStringToPoints(lineString.getCoordinates())));
LineString lineString = (LineString) geometry; ArrayList<org.apache.olingo.commons.api.edm.geo.Point> points = convertLineStringToPoints(lineString.getCoordinates()); org.apache.olingo.commons.api.edm.geo.LineString result = new org.apache.olingo.commons.api.edm.geo.LineString(dimension, srid, points); return result; } else if (geometry instanceof Polygon) { for (int i = 0; i < multiLineString.getNumGeometries(); i++) { LineString lineString = (LineString)multiLineString.getGeometryN(i); lineStrings.add(new org.apache.olingo.commons.api.edm.geo.LineString(dimension, srid, convertLineStringToPoints(lineString.getCoordinates())));