Statistics
| Revision:

root / branches / v2_0_0_prep / libraries / libFMap_geometries / src / org / gvsig / fmap / geom / primitive / impl / Circle2D.java @ 28996

History | View | Annotate | Download (12.8 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.GeometryLocator;
51
import org.gvsig.fmap.geom.Geometry.TYPES;
52
import org.gvsig.fmap.geom.handler.AbstractHandler;
53
import org.gvsig.fmap.geom.handler.CuadrantHandler;
54
import org.gvsig.fmap.geom.handler.Handler;
55
import org.gvsig.fmap.geom.primitive.Circle;
56
import org.gvsig.fmap.geom.primitive.FShape;
57
import org.gvsig.fmap.geom.primitive.GeneralPathX;
58
import org.gvsig.fmap.geom.primitive.Point;
59
import org.gvsig.fmap.geom.type.GeometryType;
60
import org.gvsig.fmap.geom.util.UtilFunctions;
61

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

    
70
        private static GeometryType geomType = GeometryLocator.getGeometryManager()
71
                        .registerGeometryType(Circle2D.class, null, TYPES.CIRCLE, SUBTYPES.GEOM2D);
72
        
73
        private Point2D center;
74
        private double radio;
75

    
76
        /**
77
         * Constructor without arguments. It is necessary to create
78
         * geometries using the {@link GeometryType}{@link #create()}
79
         * method
80
         */
81
        public Circle2D() {
82
                super();                
83
        }
84
        
85
        /**
86
         * DOCUMENT ME!
87
         *
88
         * @param gpx
89
         */
90
        public Circle2D(String id, IProjection projection, GeneralPathX gpx,
91
                        Point2D c, double r) {
92
                super(id, projection, gpx);
93
                center = c;
94
                radio = r;
95
        }
96

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

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

    
114
        /*
115
         * (non-Javadoc)
116
         * @see org.gvsig.fmap.geom.primitive.impl.Surface2D#getShapeType()
117
         */
118
        public int getShapeType() {
119
                return TYPES.CIRCLE;
120
        }
121

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

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

    
153
                return (Handler[]) handlers.toArray(new Handler[0]);
154
        }
155

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

    
172
                return (Handler[]) handlers.toArray(new Handler[0]);
173
        }
174

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

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

    
214
                /**
215
                 * @see org.gvsig.fmap.geom.handler.Handler#set(double, double)
216
                 */
217
                public void set(double x, double y) {
218
                }
219

    
220
        }
221

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

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

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

    
270
                }
271
        }
272

    
273
        /**
274
         * DOCUMENT ME!
275
         *
276
         * @author Vicente Caballero Navarro
277
         */
278
        class RadioSelHandler extends AbstractHandler implements CuadrantHandler {
279

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

    
295
                /**
296
                 * DOCUMENT ME!
297
                 *
298
                 * @param x
299
                 *            DOCUMENT ME!
300
                 * @param y
301
                 *            DOCUMENT ME!
302
                 *
303
                 * @return DOCUMENT ME!
304
                 */
305
                public void move(double x, double y) {
306

    
307
                }
308

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

    
321
        /*
322
         * (non-Javadoc)
323
         *
324
         * @see com.iver.cit.gvsig.fmap.core.FPolyline2D#intersects(java.awt.geom.Rectangle2D)
325
         */
326
        public boolean intersects(Rectangle2D r) {
327
                return gp.intersects(r);
328
        }
329

    
330
        /*
331
         * (non-Javadoc)
332
         * @see org.gvsig.fmap.geom.primitive.impl.Surface2D#getGeometryType()
333
         */
334
        public GeometryType getGeometryType() {
335
                return geomType;
336
        }        
337
        
338
        /* (non-Javadoc)
339
         * @see org.gvsig.fmap.geom.primitive.Surface2D#setGeneralPath(org.gvsig.fmap.geom.primitive.GeneralPathX)
340
         */
341
        public void setGeneralPath(GeneralPathX generalPathX) {
342
                throw new UnsupportedOperationException("Use setPoints(Point center, Point radious)");
343
        }
344

    
345
        /* (non-Javadoc)
346
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point, org.gvsig.fmap.geom.primitive.Point)
347
         */
348
        public void setPoints(Point center, Point radious) {
349
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
350
                Point2D _radious = new java.awt.geom.Point2D.Double(radious.getCoordinateAt(0), radious.getCoordinateAt(1));
351
                double dRadious = _center.distance(_radious);
352
                setPoints(center, dRadious);
353
        }
354
        
355
        /*
356
         * (non-Javadoc)
357
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point, double)
358
         */
359
        public void setPoints(Point center, double radious){
360
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
361
                java.awt.geom.Arc2D.Double arc = 
362
                        new java.awt.geom.Arc2D.Double(center.getX() - radious, _center
363
                                .getY()
364
                                - radious, 2 * radious, 2 * radious, 0, 360, Arc2D.OPEN);
365
                this.gp = new GeneralPathX(arc);
366
                this.center = _center;
367
                this.radio = radious;        
368
        }
369

    
370
        /* (non-Javadoc)
371
         * @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)
372
         */
373
        public void setPoints(Point p1, Point p2, Point p3) {
374
                Point2D _p1 = new java.awt.geom.Point2D.Double(p1.getCoordinateAt(0), p1.getCoordinateAt(1));
375
                Point2D _p2 = new java.awt.geom.Point2D.Double(p2.getCoordinateAt(0), p2.getCoordinateAt(1));
376
                Point2D _p3 = new java.awt.geom.Point2D.Double(p3.getCoordinateAt(0), p3.getCoordinateAt(1));
377
                setPoints(_p1, _p2, _p3);
378
        }
379

    
380
        /* (non-Javadoc)
381
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point2D, org.gvsig.fmap.geom.primitive.Point2D)
382
         */
383
        public void setPoints(org.gvsig.fmap.geom.primitive.impl.Point2D center,
384
                        org.gvsig.fmap.geom.primitive.impl.Point2D radious) {
385
                Point2D _center = new java.awt.geom.Point2D.Double(center.getCoordinateAt(0), center.getCoordinateAt(1));
386
                Point2D _radious = new java.awt.geom.Point2D.Double(radious.getCoordinateAt(0), radious.getCoordinateAt(1));
387
                setPoints(_center, _radious);                
388
        }
389

    
390
        /* (non-Javadoc)
391
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(org.gvsig.fmap.geom.primitive.Point2D, double)
392
         */
393
        public void setPoints(Point2D center,
394
                        double radious) {
395
                java.awt.geom.Arc2D.Double arc = 
396
                        new java.awt.geom.Arc2D.Double(center.getX() - radious, center
397
                                .getY()
398
                                - radious, 2 * radious, 2 * radious, 0, 360, Arc2D.OPEN);
399
                this.gp = new GeneralPathX(arc);
400
                this.center = center;
401
                this.radio = radious;        
402
                
403
        }
404

    
405
        /* (non-Javadoc)
406
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(java.awt.geom.Point2D, java.awt.geom.Point2D, java.awt.geom.Point2D)
407
         */
408
        public void setPoints(Point2D p1, Point2D p2, Point2D p3) {
409
                Point2D center = UtilFunctions.getCenter(p1, p2, p3);
410
                if (center != null) {
411
                        setPoints(center, p1);
412
                }
413
        }
414
        
415
        /* (non-Javadoc)
416
         * @see org.gvsig.fmap.geom.primitive.Curve#setCoordinateAt(int, int, double)
417
         */
418
        public void setCoordinateAt(int index, int dimension, double value) {
419
                throw new UnsupportedOperationException("Use setGeneralPathX");
420
        }
421

    
422
        /* (non-Javadoc)
423
         * @see org.gvsig.fmap.geom.primitive.Circle#setPoints(java.awt.geom.Point2D, java.awt.geom.Point2D)
424
         */
425
        private void setPoints(Point2D center, Point2D radious) {
426
                double radio = center.distance(radious);
427
                setPoints(center, radio);                
428
        }
429

    
430
        /* (non-Javadoc)
431
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(org.gvsig.fmap.geom.primitive.Point, double, double, double)
432
         */
433
        public void setPoints(Point center, double radius, double initAngle,
434
                        double angleExt) {
435
                throw new UnsupportedOperationException("Use setGeneralPathX");                
436
        }
437

    
438
        /* (non-Javadoc)
439
         * @see org.gvsig.fmap.geom.primitive.Arc#setPoints(java.awt.geom.Point2D, double, double, double)
440
         */
441
        private void setPoints(Point2D center, double radius, double initAngle,
442
                        double angleExt) {
443
                throw new UnsupportedOperationException("Use setGeneralPathX");                
444
        }
445

    
446
        /* (non-Javadoc)
447
         * @see org.gvsig.fmap.geom.primitive.Circle#getRadious()
448
         */
449
        public double getRadious() {
450
                return radio;
451
        }
452
        
453
        
454
}