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

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry geom, Double minmvalue, Double maxmvalue)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
16  {
17  if (args.length != 3) {
18  throw new ValueExprEvaluationException(getURI() + " requires exactly 3 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  Double value2=Double.valueOf(args[2].stringValue());
24  if(l instanceof VectorLiteral) {
25  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
26  Geometry result = relation(geom,value,value2);
27  return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
28  }
29  throw new ValueExprEvaluationException("Argument given is not a geometry literal");
30  }

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

◆ getURI()

String getURI ( )
15  {
16  return POSTGIS.st_locateBetween.stringValue();
17  }

References POSTGIS.st_locateBetween.

◆ relation()

Geometry relation ( Geometry  geom,
Double  minmvalue,
Double  maxmvalue 
)
protected

Reimplemented from GeometricModifierDoubleDoubleFunction.

20  {
21  GeometryFactory fac=new GeometryFactory();
22  List<Coordinate> resultpoint=new LinkedList<Coordinate>();
23  for(Coordinate coord:geom.getCoordinates()) {
24  if(coord.getM()>=minmvalue && coord.getM()<=maxmvalue) {
25  resultpoint.add(coord);
26  }
27  }
28  if(resultpoint.size()==1) {
29  return fac.createPoint(resultpoint.get(0));
30  }else {
31  return fac.createMultiPoint(resultpoint.toArray(new Coordinate[0]));
32  }
33  }