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

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry g1, Geometry geom2, Integer value)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
18  {
19  if (args.length != 3) {
20  throw new ValueExprEvaluationException(getURI() + " requires exactly 3 arguments, got " + args.length);
21  }
22 
23  Integer value=Integer.valueOf(args[2].stringValue());
24  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
25  LiteralType l2=LiteralRegistry.getLiteral(((Literal)args[1]).getDatatype().toString());
26  if(l instanceof VectorLiteral && l2 instanceof VectorLiteral) {
27  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
28  Geometry geom2=((VectorLiteral)l2).read(args[1].stringValue());
29  Geometry transformed=LiteralUtils.transform(geom2, geom);
30  Geometry result = relation(geom,transformed,value);
31  return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
32  }
33  throw new ValueExprEvaluationException("Arguments given are not geometry literals");
34  }

References LiteralRegistry.getLiteral(), GeometricModifierGeometryIntegerFunction.relation(), and LiteralUtils.transform().

Referenced by SetGeometryTest.testSetGeometry(), SetGeometryTest.testSetGeometryZ(), and SetRingTest.testSetRing().

◆ getURI()

String getURI ( )
14  {
15  return POSTGIS.st_setGeometry.stringValue();
16  }

References POSTGIS.st_setGeometry.

◆ relation()

Geometry relation ( Geometry  g1,
Geometry  geom2,
Integer  value 
)
protected

Reimplemented from GeometricModifierGeometryIntegerFunction.

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(geom2);
25  }else {
26  geometries.add(g1.getGeometryN(i));
27  }
28  }
29  return fac.createGeometryCollection(geometries.toArray(new Geometry[0]));
30  }