Statistics
| Revision:

svn-gvsig-desktop / branches / v2_0_0_prep / libraries / libFMap_geometries / src / org / gvsig / fmap / geom / primitive / impl / Circle2D.java @ 29097

History | View | Annotate | Download (12.6 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *  Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *      +34 963862235
28
 *   gvsig@gva.es
29
 *      www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   IVER T.I. S.A
34
 *   Salamanca 50
35
 *   46005 Valencia
36
 *   Spain
37
 *
38
 *   +34 963163400
39
 *   dac@iver.es
40
 */
41
package org.gvsig.fmap.geom.primitive.impl;
42

    
43
import java.awt.geom.AffineTransform;
44
import java.awt.geom.Arc2D;
45
import java.awt.geom.Point2D;
46
import java.awt.geom.Rectangle2D;
47
import java.util.ArrayList;
48

    
49
import org.cresques.cts.IProjection;
50
import org.gvsig.fmap.geom.Geometry;
51
import org.gvsig.fmap.geom.handler.AbstractHandler;
52
import org.gvsig.fmap.geom.handler.CuadrantHandler;
53
import org.gvsig.fmap.geom.handler.Handler;
54
import org.gvsig.fmap.geom.primitive.Circle;
55
import org.gvsig.fmap.geom.primitive.FShape;
56
import org.gvsig.fmap.geom.primitive.GeneralPathX;
57
import org.gvsig.fmap.geom.primitive.Point;
58
import org.gvsig.fmap.geom.type.GeometryType;
59
import org.gvsig.fmap.geom.util.UtilFunctions;
60

    
61
/**
62
 * DOCUMENT ME!
63
 *
64
 * @author Vicente Caballero Navarro
65
 */
66
public class Circle2D extends Surface2D implements Circle {
67
        private static final long serialVersionUID = -2709867465161215668L;
68
        
69
        private Point2D center;
70
        private double radio;
71

    
72
        /**
73
         * The constructor with the GeometryType like and argument 
74
         * is used by the {@link GeometryType}{@link #create()}
75
         * to create the geometry
76
         * @param type
77
         * The geometry type
78
         */
79
        public Circle2D(GeometryType geometryType) {
80
                super(geometryType);                
81
        }
82
        
83
        /**
84
         * Constructor used in the {@link Geometry#cloneGeometry()} method
85
         */
86
        Circle2D(GeometryType geometryType, String id, IProjection projection, GeneralPathX gpx,
87
                        Point2D c, double r) {
88
                super(geometryType, id, projection, gpx);
89
                center = c;
90
                radio = r;
91
        }
92

    
93
        /*
94
         * (non-Javadoc)
95
         * @see org.gvsig.fmap.geom.primitive.Circle#getCenter()
96
         */
97
        public Point getCenter() {
98
                return new org.gvsig.fmap.geom.primitive.impl.Point2D(center.getX(), center.getY());
99
        }
100

    
101
    /*
102
     * (non-Javadoc)
103
     * @see org.gvsig.fmap.geom.primitive.impl.Surface2D#cloneFShape()
104
     */
105
        public FShape cloneFShape() {
106
                return new Circle2D(getGeometryType(), id, projection, (GeneralPathX) gp.clone(), center,
107
                                radio);
108
        }
109

    
110
        /*
111
         * (non-Javadoc)
112
         * @see org.gvsig.fmap.geom.primitive.impl.Surface2D#getShapeType()
113
         */
114
        public int getShapeType() {
115
                return TYPES.CIRCLE;
116
        }
117

    
118
        /*
119
         * (non-Javadoc)
120
         * @see org.gvsig.fmap.geom.primitive.impl.OrientablePrimitive2D#transform(java.awt.geom.AffineTransform)
121
         */
122
        public void transform(AffineTransform at) {
123
                Point2D pdist = UtilFunctions.getPerpendicularPoint(new Point2D.Double(
124
                                center.getX() + 10, center.getY()), new Point2D.Double(center
125
                                .getX() - 10, center.getY()), center, radio);
126
                Point2D aux = new Point2D.Double();
127
                at.transform(center, aux);
128
                center = aux;
129
                Point2D aux3 = new Point2D.Double();
130
                at.transform(pdist, aux3);
131
                radio = center.distance(aux3);
132
                gp.transform(at);
133
        }
134

    
135
        /*
136
         * (non-Javadoc)
137
         * @see org.gvsig.fmap.geom.primitive.impl.OrientablePrimitive2D#getStretchingHandlers()
138
         */
139
        public Handler[] getStretchingHandlers() {
140
                ArrayList handlers = new ArrayList();
141
                Rectangle2D rect = this.getBounds2D();
142
                handlers
143
                                .add(new CenterHandler(0, rect.getCenterX(), rect.getCenterY()));
144
                // handlers.add(new RadioHandler(1, rect.getX(), rect.getCenterY()));
145
                // handlers.add(new RadioHandler(2, rect.getMaxX(), rect.getCenterY()));
146
                // handlers.add(new RadioHandler(3, rect.getCenterX(), rect.getY()));
147
                // handlers.add(new RadioHandler(3, rect.getCenterX(), rect.getMaxY()));
148

    
149
                return (Handler[]) handlers.toArray(new Handler[0]);
150
        }
151

    
152
        /*
153
         * (non-Javadoc)
154
         * @see org.gvsig.fmap.geom.primitive.impl.OrientablePrimitive2D#getSelectHandlers()
155
         */
156
        public Handler[] getSelectHandlers() {
157
                ArrayList handlers = new ArrayList();
158
                handlers.add(new CenterSelHandler(0, center.getX(), center.getY()));
159
                handlers.add(new RadioSelHandler(1, center.getX() - radio, center
160
                                .getY()));
161
                handlers.add(new RadioSelHandler(2, center.getX() + radio, center
162
                                .getY()));
163
                handlers.add(new RadioSelHandler(3, center.getX(), center.getY()
164
                                - radio));
165
                handlers.add(new RadioSelHandler(3, center.getX(), center.getY()
166
                                + radio));
167

    
168
                return (Handler[]) handlers.toArray(new Handler[0]);
169
        }
170

    
171
        /**
172
         * DOCUMENT ME!
173
         *
174
         * @author Vicente Caballero Navarro
175
         */
176
        class CenterHandler extends AbstractHandler implements Handler {
177
                /**
178
                 * Crea un nuevo PointHandler.
179
                 *
180
                 * @param i
181
                 *            DOCUMENT ME!
182
                 * @param x
183
                 *            DOCUMENT ME!
184
                 * @param y
185
                 *            DOCUMENT ME!
186
                 */
187
                public CenterHandler(int i, double x, double y) {
188
                        point = new Point2D.Double(x, y);
189
                        index = i;
190
                }
191

    
192
                /**
193
                 * DOCUMENT ME!
194
                 *
195
                 * @param x
196
                 *            DOCUMENT ME!
197
                 * @param y
198
                 *            DOCUMENT ME!
199
                 *
200
                 * @return DOCUMENT ME!
201
                 */
202
                public void move(double x, double y) {
203
                        center = new Point2D.Double(center.getX() + x, center.getY() + y);
204
                        for (int i = 0; i < gp.getNumCoords() / 2; i++) {
205
                                gp.getPointCoords()[i * 2] += x;
206
                                gp.getPointCoords()[i * 2 + 1] += y;
207
                        }
208
                }
209

    
210
                /**
211
                 * @see org.gvsig.fmap.geom.handler.Handler#set(double, double)
212
                 */
213
                public void set(double x, double y) {
214
                }
215

    
216
        }
217

    
218
        /**
219
         * DOCUMENT ME!
220
         *
221
         * @author Vicente Caballero Navarro
222
         */
223
        class CenterSelHandler extends AbstractHandler implements Handler {
224
                /**
225
                 * Crea un nuevo PointHandler.
226
                 *
227
                 * @param i
228
                 *            DOCUMENT ME!
229
                 * @param x
230
                 *            DOCUMENT ME!
231
                 * @param y
232
                 *            DOCUMENT ME!
233
                 */
234
                public CenterSelHandler(int i, double x, double y) {
235
                        point = new Point2D.Double(x, y);
236
                        index = i;
237
                }
238

    
239
                /**
240
                 * DOCUMENT ME!
241
                 *
242
                 * @param x
243
                 *            DOCUMENT ME!
244
                 * @param y
245
                 *            DOCUMENT ME!
246
                 *
247
                 * @return DOCUMENT ME!
248
                 */
249
                public void move(double x, double y) {
250
                        for (int i = 0; i < gp.getNumCoords() / 2; i++) {
251
                                gp.getPointCoords()[i * 2] += x;
252
                                gp.getPointCoords()[i * 2 + 1] += y;
253
                        }
254
                }
255

    
256
                /**
257
                 * @see org.gvsig.fmap.geom.handler.Handler#set(double, double)
258
                 */
259
                public void set(double x, double y) {
260
                        center = new Point2D.Double(x, y);
261
                        Arc2D.Double arc = new Arc2D.Double(center.getX() - radio, center
262
                                        .getY()
263
                                        - radio, 2 * radio, 2 * radio, 0, 360, Arc2D.OPEN);
264
                        gp = new GeneralPathX(arc);
265

    
266
                }
267
        }
268

    
269
        /**
270
         * DOCUMENT ME!
271
         *
272
         * @author Vicente Caballero Navarro
273
         */
274
        class RadioSelHandler extends AbstractHandler implements CuadrantHandler {
275

    
276
                /**
277
                 * Crea un nuevo PointHandler.
278
                 *
279
                 * @param i
280
                 *            DOCUMENT ME!
281
                 * @param x
282
                 *            DOCUMENT ME!
283
                 * @param y
284
                 *            DOCUMENT ME!
285
                 */
286
                public RadioSelHandler(int i, double x, double y) {
287
                        point = new Point2D.Double(x, y);
288
                        index = i;
289
                }
290

    
291
                /**
292
                 * DOCUMENT ME!
293
                 *
294
                 * @param x
295
                 *            DOCUMENT ME!
296
                 * @param y
297
                 *            DOCUMENT ME!
298
                 *
299
                 * @return DOCUMENT ME!
300
                 */
301
                public void move(double x, double y) {
302

    
303
                }
304

    
305
                /**
306
                 * @see org.gvsig.fmap.geom.handler.Handler#set(double, double)
307
                 */
308
                public void set(double x, double y) {
309
                        radio = center.distance(x, y);
310
                        Arc2D.Double arc = new Arc2D.Double(center.getX() - radio, center
311
                                        .getY()
312
                                        - radio, 2 * radio, 2 * radio, 0, 360, Arc2D.OPEN);
313
                        gp = new GeneralPathX(arc);
314
                }
315
        }
316

    
317
        /*
318
         * (non-Javadoc)
319
         *
320
         * @see com.iver.cit.gvsig.fmap.core.FPolyline2D#intersects(java.awt.geom.Rectangle2D)
321
         */
322
        public boolean intersects(Rectangle2D r) {
323
                return gp.intersects(r);
324
        }
325
        
326
        /* (non-Javadoc)
327
         * @see org.gvsig.fmap.geom.primitive.Surface2D#setGeneralPath(org.gvsig.fmap.geom.primitive.GeneralPathX)
328
         */
329
        public void setGeneralPath(GeneralPathX generalPathX) {
330
                throw new UnsupportedOperationException("Use setPoints(Point center, Point radious)");
331
        }
332

    
333
        /* (non-Javadoc)
334
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point, org.gvsig.fmap.geom.primitive.Point)
335
         */
336
        public void setPoints(Point center, Point radious) {
337
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
338
                Point2D _radious = new java.awt.geom.Point2D.Double(radious.getCoordinateAt(0), radious.getCoordinateAt(1));
339
                double dRadious = _center.distance(_radious);
340
                setPoints(center, dRadious);
341
        }
342
        
343
        /*
344
         * (non-Javadoc)
345
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point, double)
346
         */
347
        public void setPoints(Point center, double radious){
348
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
349
                java.awt.geom.Arc2D.Double arc = 
350
                        new java.awt.geom.Arc2D.Double(center.getX() - radious, _center
351
                                .getY()
352
                                - radious, 2 * radious, 2 * radious, 0, 360, Arc2D.OPEN);
353
                this.gp = new GeneralPathX(arc);
354
                this.center = _center;
355
                this.radio = radious;        
356
        }
357

    
358
        /* (non-Javadoc)
359
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(org.gvsig.fmap.geom.primitive.Point, org.gvsig.fmap.geom.primitive.Point, org.gvsig.fmap.geom.primitive.Point)
360
         */
361
        public void setPoints(Point p1, Point p2, Point p3) {
362
                Point2D _p1 = new java.awt.geom.Point2D.Double(p1.getCoordinateAt(0), p1.getCoordinateAt(1));
363
                Point2D _p2 = new java.awt.geom.Point2D.Double(p2.getCoordinateAt(0), p2.getCoordinateAt(1));
364
                Point2D _p3 = new java.awt.geom.Point2D.Double(p3.getCoordinateAt(0), p3.getCoordinateAt(1));
365
                setPoints(_p1, _p2, _p3);
366
        }
367

    
368
        /* (non-Javadoc)
369
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point2D, org.gvsig.fmap.geom.primitive.Point2D)
370
         */
371
        public void setPoints(org.gvsig.fmap.geom.primitive.impl.Point2D center,
372
                        org.gvsig.fmap.geom.primitive.impl.Point2D radious) {
373
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
374
                Point2D _radious = new java.awt.geom.Point2D.Double(radious.getCoordinateAt(0), radious.getCoordinateAt(1));
375
                setPoints(_center, _radious);                
376
        }
377

    
378
        /* (non-Javadoc)
379
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point2D, double)
380
         */
381
        public void setPoints(Point2D center,
382
                        double radious) {
383
                java.awt.geom.Arc2D.Double arc = 
384
                        new java.awt.geom.Arc2D.Double(center.getX() - radious, center
385
                                .getY()
386
                                - radious, 2 * radious, 2 * radious, 0, 360, Arc2D.OPEN);
387
                this.gp = new GeneralPathX(arc);
388
                this.center = center;
389
                this.radio = radious;        
390
                
391
        }
392

    
393
        /* (non-Javadoc)
394
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(java.awt.geom.Point2D, java.awt.geom.Point2D, java.awt.geom.Point2D)
395
         */
396
        public void setPoints(Point2D p1, Point2D p2, Point2D p3) {
397
                Point2D center = UtilFunctions.getCenter(p1, p2, p3);
398
                if (center != null) {
399
                        setPoints(center, p1);
400
                }
401
        }
402
        
403
        /* (non-Javadoc)
404
         * @see org.gvsig.fmap.geom.primitive.Curve#setCoordinateAt(int, int, double)
405
         */
406
        public void setCoordinateAt(int index, int dimension, double value) {
407
                throw new UnsupportedOperationException("Use setGeneralPathX");
408
        }
409

    
410
        /* (non-Javadoc)
411
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(java.awt.geom.Point2D, java.awt.geom.Point2D)
412
         */
413
        private void setPoints(Point2D center, Point2D radious) {
414
                double radio = center.distance(radious);
415
                setPoints(center, radio);                
416
        }
417

    
418
        /* (non-Javadoc)
419
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(org.gvsig.fmap.geom.primitive.Point, double, double, double)
420
         */
421
        public void setPoints(Point center, double radius, double initAngle,
422
                        double angleExt) {
423
                throw new UnsupportedOperationException("Use setGeneralPathX");                
424
        }
425

    
426
        /* (non-Javadoc)
427
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(java.awt.geom.Point2D, double, double, double)
428
         */
429
        private void setPoints(Point2D center, double radius, double initAngle,
430
                        double angleExt) {
431
                throw new UnsupportedOperationException("Use setGeneralPathX");                
432
        }
433

    
434
        /* (non-Javadoc)
435
         * @see org.gvsig.fmap.geom.primitive.Circle#getRadious()
436
         */
437
        public double getRadious() {
438
                return radio;
439
        }
440
        
441
        
442
}