Statistics
| Revision:

root / branches / v2_0_0_prep / libraries / libFMap_geometries / src / org / gvsig / fmap / geom / operation / distance / PointDistance.java @ 29798

History | View | Annotate | Download (2.54 KB)

1
/* gvSIG. Geographic Information System of the Valencian Government
2
*
3
* Copyright (C) 2007-2008 Infrastructures and Transports Department
4
* of the Valencian Government (CIT)
5
* 
6
* This program is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU General Public License
8
* as published by the Free Software Foundation; either version 2
9
* of the License, or (at your option) any later version.
10
* 
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
* GNU General Public License for more details.
15
* 
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
19
* MA  02110-1301, USA.
20
* 
21
*/
22

    
23
/*
24
* AUTHORS (In addition to CIT):
25
* 2009 {Iver T.I.}   {Task}
26
*/
27
 
28
package org.gvsig.fmap.geom.operation.distance;
29

    
30
import java.awt.geom.Point2D;
31

    
32
import org.gvsig.fmap.geom.Geometry;
33
import org.gvsig.fmap.geom.GeometryLocator;
34
import org.gvsig.fmap.geom.Geometry.TYPES;
35
import org.gvsig.fmap.geom.operation.GeometryOperation;
36
import org.gvsig.fmap.geom.operation.GeometryOperationContext;
37
import org.gvsig.fmap.geom.operation.GeometryOperationException;
38
import org.gvsig.fmap.geom.primitive.Point;
39
import org.gvsig.fmap.geom.type.GeometryType;
40

    
41
/**
42
 * @author <a href="mailto:jpiera@gvsig.org">Jorge Piera</a>
43
 */
44
public class PointDistance extends GeometryOperation{
45
    public static final String NAME = "distance";
46
        public static final int CODE = GeometryLocator.getGeometryManager().
47
            getGeometryOperationCode(NAME);
48
        
49
        /* (non-Javadoc)
50
         * @see org.gvsig.fmap.geom.operation.GeometryOperation#getOperationIndex()
51
         */
52
        public int getOperationIndex() {
53
                return CODE;
54
        }
55

    
56
        /* (non-Javadoc)
57
         * @see org.gvsig.fmap.geom.operation.GeometryOperation#invoke(org.gvsig.fmap.geom.Geometry, org.gvsig.fmap.geom.operation.GeometryOperationContext)
58
         */
59
        public Object invoke(Geometry geom, GeometryOperationContext ctx)
60
                        throws GeometryOperationException {
61
                Geometry geom2 = (Geometry)ctx.getAttribute("geom");
62
                GeometryType geomType2 = geom2.getGeometryType();
63
                
64
                if ((TYPES.POINT != geom.getType()) && TYPES.POINT != geomType2.getType()){
65
                        throw new UnsupportedOperationException("The distance only can be execudet between two points");
66
                }
67
                
68
                return new Double(Point2D.distance(((Point)geom).getX(),
69
                                ((Point)geom).getY(),
70
                                ((Point)geom2).getX(),
71
                                ((Point)geom2).getX()));
72
        }
73
}
74