rdf4j-postgis  Version 0.1.0.0
SubdivideLines Class Reference

Subdivides lines of a given LineString. More...

Inheritance diagram for SubdivideLines:
Collaboration diagram for SubdivideLines:

Public Member Functions

String getURI ()
 
List< LineString > createSegments (Geometry track, double numberOfPoints) throws NoSuchAuthorityCodeException, FactoryException
 
Value evaluate (ValueFactory valueFactory, Value... args) throws ValueExprEvaluationException
 

Protected Member Functions

Geometry relation (Geometry geom, Double value)
 

Detailed Description

Subdivides lines of a given LineString.

Member Function Documentation

◆ createSegments()

List<LineString> createSegments ( Geometry  track,
double  numberOfPoints 
) throws NoSuchAuthorityCodeException, FactoryException
42  {
43  GeometryFactory fac=new GeometryFactory();
44  //GeometryFactory geometryFactory = new GeometryFactory(new PrecisionModel(PrecisionModel.FLOATING));
45  List<LineString> segments = new ArrayList<>();
46  int i=0;
47  for(int j=0;j<track.getNumGeometries();j++) {
48  List<Coordinate> coords=new LinkedList<Coordinate>();
49  for(Coordinate coord:track.getGeometryN(j).getCoordinates()) {
50  if(i<numberOfPoints) {
51  coords.add(coord);
52  }else {
53  segments.add(fac.createLineString(coords.toArray(new Coordinate[0])));
54  coords=new LinkedList<Coordinate>();
55  i=0;
56  }
57  }
58  }
59  return segments;
60  }

Referenced by SubdivideLines.relation().

◆ 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  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
22  Double value=Double.valueOf(args[1].stringValue());
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 GeometricModifierDoubleFunction.relation().

Referenced by DensifyTest.testDensify(), EnsureClosedTest.testEnsureClosed(), EnsureClosedTest.testEnsureClosed2(), RemoveGeometryTest.testRemoveGeometry1(), RemoveGeometryTest.testRemoveGeometry1Z(), RemoveGeometryTest.testRemoveGeometry2(), RemoveGeometryTest.testRemoveGeometry2Z(), RemoveRepeatedPointsTest.testRemoveRepeatedPoints(), SimplifyTest.testSimplify(), and SimplifyVWTest.testSimplifyVW().

◆ getURI()

String getURI ( )
22  {
23  return POSTGIS.st_subdividelines.stringValue();
24  }

References POSTGIS.st_subdividelines.

◆ relation()

Geometry relation ( Geometry  geom,
Double  value 
)
protected

Reimplemented from GeometricModifierDoubleFunction.

27  {
28  double segmentLength = value;
29 
30  List<LineString> linestrings;
31  try {
32  linestrings = createSegments(geom, segmentLength);
33  GeometryFactory fac=new GeometryFactory();
34  return fac.createMultiLineString(linestrings.toArray(new LineString[0]));
35  } catch (FactoryException e) {
36  // TODO Auto-generated catch block
37  e.printStackTrace();
38  }
39  return null;
40  }
List< LineString > createSegments(Geometry track, double numberOfPoints)
Definition: SubdivideLines.java:42

References SubdivideLines.createSegments().