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 / STDimensionFunction.java @ 44644

History | View | Annotate | Download (1.27 KB)

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.type.GeometryType;
8

    
9
public class STDimensionFunction extends AbstractGeometryFunction {
10

    
11
    public STDimensionFunction() {
12
        super("OGC", "ST_Dimension", Range.is(1));
13
    }
14

    
15
    @Override
16
    public boolean allowConstantFolding() {
17
        return true;
18
    }
19
    
20
    @Override
21
    public Object call(Interpreter interpreter, Object[] args) throws Exception {
22
        Geometry geom = getGeom(args, 0);
23
        GeometryType type = geom.getGeometryType();
24
        if( type.isSubTypeOf(Geometry.TYPES.POINT)
25
            || type.isSubTypeOf(Geometry.TYPES.MULTIPOINT) ) {
26
            return 0;
27
        }
28
        if( type.isSubTypeOf(Geometry.TYPES.CURVE)
29
            || type.isSubTypeOf(Geometry.TYPES.MULTICURVE) ) {
30
            return 1;
31
        }
32
        if( type.isSubTypeOf(Geometry.TYPES.SURFACE)
33
            || type.isSubTypeOf(Geometry.TYPES.MULTISURFACE) ) {
34
            return 2;
35
        }
36
        if( type.isSubTypeOf(Geometry.TYPES.SOLID) ) {
37
            return 3;
38
        }
39
        return -1;
40
    }
41

    
42
}