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

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry g1, 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 ( )
14  {
15  return POSTGIS.st_removeGeometry.stringValue();
16  }

References POSTGIS.st_removeGeometry.

◆ relation()

Geometry relation ( Geometry  g1,
Double  value 
)
protected

Reimplemented from GeometricModifierDoubleFunction.

19  {
20  GeometryFactory fac=new GeometryFactory();
21  List<Geometry> geometries=new LinkedList<Geometry>();
22  for(int i=0;i<g1.getNumGeometries();i++) {
23  if(value!=i) {
24  geometries.add(g1.getGeometryN(i));
25  }
26  }
27  return fac.createGeometryCollection(geometries.toArray(new Geometry[0]));
28  }