17 if (args.length != 5) {
18 throw new ValueExprEvaluationException(getURI() +
" requires exactly 2 arguments, got " + args.length);
20 LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
21 if(l instanceof VectorLiteral) {
22 Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
23 String pixeltype=args[1].stringValue();
24 Double value=Double.valueOf(args[2].stringValue());
25 Double nodata=Double.valueOf(args[3].stringValue());
26 Boolean touched=Boolean.valueOf(args[4].stringValue());
27 Geometry result =
relation(geom,pixeltype,value,nodata,touched);
28 return valueFactory.createLiteral(((VectorLiteral) l).unparse(result),((Literal)args[0]).getDatatype());
30 throw new ValueExprEvaluationException(
"Arguments given are not geometry literals");
abstract Geometry relation(Geometry geom, String pixeltype, Double value, Double nodataval, Boolean touched)