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

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

References LiteralRegistry.getLiteral(), and GeometricRelationModifierFunction.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) {
24  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
25  Geometry geom2=((VectorLiteral)l2).read(args[1].stringValue());
26  Geometry result = relation(geom,geom2);
27  return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
28  }
29  throw new ValueExprEvaluationException("Arguments given are not geometry literals");
30  }

◆ getURI()

String getURI ( )

References POSTGIS.st_sharedPaths.

15  {
16  return POSTGIS.st_sharedPaths.stringValue();
17  }

◆ relation()

Geometry relation ( Geometry  geom1,
Geometry  geom2 
)
protected

References LiteralUtils.createGeometryCollection(), and LiteralUtils.transform().

20  {
21  List<Geometry> intersections=new LinkedList<>();
22  Geometry transformed=LiteralUtils.transform(geom2, geom1);
23  if((geom1.getGeometryType().equals("MultiLineString") || geom1.getGeometryType().equals("LineString"))
24  && (transformed.getGeometryType().equals("MultiLineString") || transformed.getGeometryType().equals("LineString"))) {
25  for(int i=0;i<geom1.getNumGeometries();i++) {
26  for(int j=0;j<transformed.getNumGeometries();j++) {
27  if(geom1.intersects(transformed.getGeometryN(j))){
28  intersections.add(geom1.getGeometryN(i).intersection(transformed.getGeometryN(j)));
29  }
30  }
31  }
32  return LiteralUtils.createGeometryCollection(intersections, "GEOMETRYCOLLECTION", geom1.getSRID());
33  }
34  return null;
35  }