rdf4j-postgis  Version 0.1.0.0
GeneratePoints Class Reference

Generates a given number of points in a convex hull of a geometry. More...

Inheritance diagram for GeneratePoints:
Collaboration diagram for GeneratePoints:

Public Member Functions

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

Protected Member Functions

Geometry relation (Geometry geom, Integer amount)
 

Detailed Description

Generates a given number of points in a convex hull of a geometry.

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 ( )
14  {
15  return POSTGIS.st_generatePoints.stringValue();
16  }

References POSTGIS.st_generatePoints.

◆ relation()

Geometry relation ( Geometry  geom,
Integer  amount 
)
protected

Reimplemented from GeometricModifierIntegerFunction.

19  {
20  RandomPointsBuilder shapeBuilder = new RandomPointsBuilder(geom.getFactory());
21  shapeBuilder.setNumPoints(amount.intValue());
22  if(!geom.getGeometryType().equalsIgnoreCase("Polygon")) {
23  System.out.println(geom.getGeometryType());
24  Geometry convhull=geom.convexHull();
25  System.out.println(convhull.getGeometryType());
26  if(!convhull.getGeometryType().equalsIgnoreCase("Polygon")) {
27  convhull=convhull.convexHull();
28  }
29  System.out.println(convhull.getGeometryType()+"=====");
30  shapeBuilder.setExtent(convhull);
31  }else {
32  shapeBuilder.setExtent(geom);
33  }
34  return shapeBuilder.getGeometry();
35  }