Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.library / org.gvsig.expressionevaluator / org.gvsig.expressionevaluator.geometry / org.gvsig.expressionevaluator.geometry.lib / org.gvsig.expressionevaluator.geometry.lib.impl / src / main / java / org / gvsig / expressionevaluator / impl / function / spatial / STEndPointFunction.java @ 44644

History | View | Annotate | Download (1002 Bytes)

1
package org.gvsig.expressionevaluator.impl.function.spatial;
2

    
3
import org.apache.commons.lang3.Range;
4
import org.gvsig.expressionevaluator.Interpreter;
5
import org.gvsig.expressionevaluator.spi.AbstractGeometryFunction;
6
import org.gvsig.fmap.geom.Geometry;
7
import org.gvsig.fmap.geom.primitive.OrientablePrimitive;
8
import org.gvsig.fmap.geom.primitive.Point;
9

    
10
public class STEndPointFunction extends AbstractGeometryFunction {
11

    
12
    public STEndPointFunction() {
13
        super("OGC", "ST_EndPoint", Range.is(1));
14
    }
15
    
16
    @Override
17
    public boolean allowConstantFolding() {
18
        return true;
19
    }
20
    
21
    @Override
22
    public Object call(Interpreter interpreter, Object[] args) throws Exception {
23
        Geometry geom = getGeom(args, 0);
24
        if ( geom instanceof OrientablePrimitive ) {
25
            int n = ((OrientablePrimitive) geom).getNumVertices();
26
            Point p = ((OrientablePrimitive) geom).getVertex(n-1);
27
            return p;
28
        }
29
        return null;
30
    }
31
    
32
}