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 43512 jjdelcerro
package org.gvsig.expressionevaluator.impl.function.spatial;
2
3
import org.apache.commons.lang3.Range;
4 43521 jjdelcerro
import org.gvsig.expressionevaluator.Interpreter;
5 44644 jjdelcerro
import org.gvsig.expressionevaluator.spi.AbstractGeometryFunction;
6 43518 jjdelcerro
import org.gvsig.fmap.geom.Geometry;
7
import org.gvsig.fmap.geom.primitive.OrientablePrimitive;
8
import org.gvsig.fmap.geom.primitive.Point;
9 43512 jjdelcerro
10 44644 jjdelcerro
public class STEndPointFunction extends AbstractGeometryFunction {
11 43512 jjdelcerro
12 43518 jjdelcerro
    public STEndPointFunction() {
13
        super("OGC", "ST_EndPoint", Range.is(1));
14 43512 jjdelcerro
    }
15
16
    @Override
17 44009 jjdelcerro
    public boolean allowConstantFolding() {
18
        return true;
19
    }
20
21
    @Override
22 43521 jjdelcerro
    public Object call(Interpreter interpreter, Object[] args) throws Exception {
23 43518 jjdelcerro
        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 43512 jjdelcerro
    }
31
32
}