kiwi-postgis  Version 0.1.0.0
MaxDistance Class Reference
Inheritance diagram for MaxDistance:
Collaboration diagram for MaxDistance:

Public Member Functions

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

Protected Member Functions

double relation (Geometry geom1, Geometry geom2)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited

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

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  LiteralType l2=LiteralRegistry.getLiteral(((Literal)args[1]).getDatatype().toString());
23  if(l instanceof VectorLiteral && l2 instanceof VectorLiteral) {
24  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
25  Geometry geom2=((VectorLiteral)l).read(args[1].stringValue());
26  double result = relation(geom,geom2);
27  return valueFactory.createLiteral(result);
28  }
29  throw new ValueExprEvaluationException("Arguments given are not a geometry literal");
30 
31  }

◆ getURI()

String getURI ( )

References POSTGIS.st_maxDistance.

12  {
13  return POSTGIS.st_maxDistance.stringValue();
14  }

◆ relation()

double relation ( Geometry  geom1,
Geometry  geom2 
)
protected

References LiteralUtils.transform().

17  {
18  Double maxDistance=0.;
19  Geometry transformed=LiteralUtils.transform(geom2, geom1);
20  for(Coordinate coord:geom1.getCoordinates()) {
21  for(Coordinate coord2:transformed.getCoordinates()) {
22  Double curdistance=coord.distance(coord2);
23  if(curdistance>maxDistance) {
24  maxDistance=curdistance;
25  }
26  }
27  }
28  return maxDistance;
29  }