rdf4j-postgis  Version 0.1.0.0
EnsureClosedRings Class Reference
Inheritance diagram for EnsureClosedRings:
Collaboration diagram for EnsureClosedRings:

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry geom, Double value)
 

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  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
22  Double value=Double.valueOf(args[1].stringValue());
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 GeometricModifierDoubleFunction.relation().

Referenced by DensifyTest.testDensify(), EnsureClosedTest.testEnsureClosed(), EnsureClosedTest.testEnsureClosed2(), RemoveGeometryTest.testRemoveGeometry1(), RemoveGeometryTest.testRemoveGeometry1Z(), RemoveGeometryTest.testRemoveGeometry2(), RemoveGeometryTest.testRemoveGeometry2Z(), RemoveRepeatedPointsTest.testRemoveRepeatedPoints(), SimplifyTest.testSimplify(), and SimplifyVWTest.testSimplifyVW().

◆ getURI()

String getURI ( )
17  {
18  return POSTGIS.st_ensureClosedRings.stringValue();
19  }

References POSTGIS.st_ensureClosedRings.

◆ relation()

Geometry relation ( Geometry  geom,
Double  value 
)
protected

Reimplemented from GeometricModifierDoubleFunction.

22  {
23  if(geom instanceof Polygon) {
24  GeometryFactory fac=new GeometryFactory();
25 
26  Polygon poly=(Polygon) geom;
27  List<LinearRing> rings=new LinkedList<LinearRing>();
28  for(int i=0;i<poly.getNumInteriorRing();i++) {
29  if(!poly.getInteriorRingN(i).isClosed()) {
30  LinearRing ring=(LinearRing)poly.getInteriorRingN(i);
31  List<Coordinate> coords=new LinkedList<Coordinate>();
32  for(Coordinate coord:ring.getCoordinates()) {
33  coords.add(coord);
34  }
35  coords.add(ring.getCoordinates()[0]);
36  rings.add(fac.createLinearRing(coords.toArray(new Coordinate[0])));
37  }else {
38  rings.add((LinearRing)poly.getInteriorRingN(i));
39  }
40  }
41  }
42  return null;
43  }