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

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry geom, Integer type)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
16  {
17  if (args.length != 2) {
18  throw new ValueExprEvaluationException(getURI() + " requires exactly 2 arguments, got " + args.length);
19  }
20 
21  Integer value=Integer.valueOf(args[1].stringValue());
22  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
23  if(l instanceof VectorLiteral) {
24  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
25  Geometry result = relation(geom,value);
26  return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
27  }
28  throw new ValueExprEvaluationException("Argument given is not a geometry literal");
29  }

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

Referenced by CollectionExtractTest.testCollectionExtract(), GeneratePointsTest.testGeneratePoints(), PointNTest.testLineString(), PrecisionReducerTest.testPrecisionReducer(), RemovePointTest.testRemovePoint(), RemovePointTest.testRemovePointZ(), RemoveRingTest.testRemoveRing(), and ReverseRingTest.testReverseRing().

◆ getURI()

String getURI ( )
18  {
19  return POSTGIS.st_collectionextract.stringValue();
20  }

References POSTGIS.st_collectionextract.

◆ relation()

Geometry relation ( Geometry  geom,
Integer  type 
)
protected

Reimplemented from GeometricModifierIntegerFunction.

23  {
24  GeometryFactory fac=new GeometryFactory();
25  GeometryCollection collection=(GeometryCollection)geom;
26  switch(type) {
27  case 1:
28  List<Coordinate> coords=new ArrayList<Coordinate>();
29  for(int i=0;i<collection.getNumGeometries();i++) {
30  for(Coordinate coord2:collection.getGeometryN(i).getCoordinates()) {
31  coords.add(coord2);
32  }
33  }
34  if(coords.size()==1) {
35  return fac.createPoint(coords.get(0));
36  }
37  return fac.createMultiPointFromCoords(coords.toArray(new Coordinate[0]));
38  case 2:
39  List<LineString> lines=new ArrayList<LineString>();
40  for(int i=0;i<collection.getNumGeometries();i++) {
41  lines.add((LineString)collection.getGeometryN(i));
42  }
43  return fac.createMultiLineString(lines.toArray(new LineString[0]));
44  case 3:
45  List<Polygon> polys=new ArrayList<Polygon>();
46  for(int i=0;i<collection.getNumGeometries();i++) {
47  polys.add((Polygon)collection.getGeometryN(i));
48  }
49  return fac.createMultiPolygon(polys.toArray(new Polygon[0]));
50  }
51  return null;
52  }