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

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry geom1, Geometry geom2)
 

Member Function Documentation

◆ evaluate()

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

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

Referenced by LongestLineTest.testLongestLine(), ShortestLineTest.testShortestLine(), and ShortestLine3DTest.testShortestLine3D().

◆ getURI()

String getURI ( )
13  {
14  return POSTGIS.st_longestLine.stringValue();
15  }

References POSTGIS.st_longestLine.

◆ relation()

Geometry relation ( Geometry  geom1,
Geometry  geom2 
)
protected

Reimplemented from GeometricRelationModifierFunction.

19  {
20  Double maxDistance=0.;
21  Coordinate maxCoord1=null;
22  Coordinate maxCoord2=null;
23  for(Coordinate coord:geom1.getCoordinates()) {
24  for(Coordinate coord2:geom2.getCoordinates()) {
25  Double curdistance=coord.distance(coord2);
26  if(curdistance>maxDistance) {
27  maxDistance=curdistance;
28  maxCoord1=coord;
29  maxCoord2=coord2;
30  }
31  }
32  }
33  return LiteralUtils.createGeometry(new Coordinate[] {maxCoord1,maxCoord2},"LineString", geom1.getSRID());
34  }

References LiteralUtils.createGeometry().