rdf4j-postgis  Version 0.1.0.0
ReverseRing Class Reference

Reverses the coordinates of a given ring of a polygon. More...

Inheritance diagram for ReverseRing:
Collaboration diagram for ReverseRing:

Public Member Functions

String getURI ()
 
Value evaluate (ValueFactory valueFactory, Value... args) throws ValueExprEvaluationException
 

Protected Member Functions

Geometry relation (Geometry geom, Integer value)
 

Detailed Description

Reverses the coordinates of a given ring of a polygon.

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
16  {
17  if (args.length != 2) {
18  throw new ValueExprEvaluationException(getURI() + " requires exactly 2 arguments, got " + args.length);
19  }
20 
21  Integer value=Integer.valueOf(args[1].stringValue());
22  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
23  if(l instanceof VectorLiteral) {
24  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
25  Geometry result = relation(geom,value);
26  return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
27  }
28  throw new ValueExprEvaluationException("Argument given is not a geometry literal");
29  }

References LiteralRegistry.getLiteral(), and GeometricModifierIntegerFunction.relation().

Referenced by CollectionExtractTest.testCollectionExtract(), GeneratePointsTest.testGeneratePoints(), PointNTest.testLineString(), PrecisionReducerTest.testPrecisionReducer(), RemovePointTest.testRemovePoint(), RemovePointTest.testRemovePointZ(), RemoveRingTest.testRemoveRing(), and ReverseRingTest.testReverseRing().

◆ getURI()

String getURI ( )
21  {
22  return POSTGIS.st_reverseRing.toString();
23  }

References POSTGIS.st_reverseRing.

◆ relation()

Geometry relation ( Geometry  geom,
Integer  value 
)
protected

Reimplemented from GeometricModifierIntegerFunction.

26  {
27  if(geom instanceof Polygon) {
28  Polygon poly=(Polygon) geom;
29  if(value<0 || value>poly.getNumInteriorRing()) {
30  return geom;
31  }
32  List<LinearRing> rings=new LinkedList<LinearRing>();
33  for(int i=0;i<poly.getNumInteriorRing();i++) {
34  if(i==value) {
35  List<Coordinate> newring=new LinkedList<Coordinate>();
36  for(int j=poly.getInteriorRingN(i).getCoordinates().length-1;j>=0;j--) {
37  newring.add(poly.getInteriorRingN(i).getCoordinateN(j));
38  }
39  GeometryFactory fac=new GeometryFactory();
40  rings.add(fac.createLinearRing(newring.toArray(new Coordinate[0])));
41  }else {
42  rings.add((LinearRing)poly.getInteriorRingN(i));
43  }
44  }
45  GeometryFactory fac=new GeometryFactory();
46  return fac.createPolygon((LinearRing)poly.getExteriorRing(), rings.toArray(new LinearRing[0]));
47  }
48  return null;
49  }