Statistics
| Revision:

root / trunk / applications / appgvSIG / src / com / iver / cit / gvsig / project / documents / layout / tools / listener / LayoutAddRectangleListener.java @ 9392

History | View | Annotate | Download (4.7 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 com.iver.cit.gvsig.project.documents.layout.tools.listener;
42

    
43
import java.awt.Image;
44
import java.awt.geom.Point2D;
45
import java.awt.geom.Rectangle2D;
46

    
47
import javax.swing.ImageIcon;
48

    
49
import com.iver.andami.PluginServices;
50
import com.iver.cit.gvsig.fmap.MapControl;
51
import com.iver.cit.gvsig.fmap.tools.BehaviorException;
52
import com.iver.cit.gvsig.fmap.tools.Events.RectangleEvent;
53
import com.iver.cit.gvsig.project.documents.layout.fframes.FFrameGraphics;
54
import com.iver.cit.gvsig.project.documents.layout.gui.Layout;
55

    
56

    
57
/**
58
 * Implementaci?n de la interfaz LayoutRectangleListener como herramienta para
59
 * realizar una inserci?n por rect?ngulo.
60
 *
61
 * @author Vicente Caballero Navarro
62
 */
63
public class LayoutAddRectangleListener implements LayoutRectangleListener {
64
        private final Image img = new ImageIcon(MapControl.class.getResource(
65
                                "images/RectSelectCursor.gif")).getImage();
66
        protected Layout layout;
67
        protected static int TOLERANCE=20;
68

    
69
        /**
70
         * Crea un nuevo LayoutAddRectangleListener.
71
         *
72
         * @param l Layout.
73
         */
74
        public LayoutAddRectangleListener(Layout l) {
75
                this.layout = l;
76
        }
77

    
78
        /**
79
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.RectangleListener#rectangle(com.iver.cit.gvsig.fmap.tools.Events.RectangleEvent)
80
         */
81
        public void rectangle(RectangleEvent event) throws BehaviorException {
82
                FFrameGraphics fframe = new FFrameGraphics();
83
                fframe.setLayout(layout);
84
                fframe.setGeometryAdapter(layout.getLayoutControl().getGeometryAdapter());
85
                fframe.update(FFrameGraphics.RECTANGLE, layout.getLayoutControl().getAT());
86
                fframe.setBoundBox(layout.getLayoutControl().getGeometryAdapter().getBounds2D());
87
                layout.getLayoutContext().addFFrame(fframe, true,true);
88
                PluginServices.getMainFrame().enableControls();
89
        layout.getLayoutControl().refresh();
90
        }
91

    
92
        /**
93
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.ToolListener#getCursor()
94
         */
95
        public Image getImageCursor() {
96
                return img;
97
        }
98

    
99
        /**
100
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.ToolListener#cancelDrawing()
101
         */
102
        public boolean cancelDrawing() {
103
                return false;
104
        }
105
        protected Rectangle2D getRectangle(int tolerance) {
106
                Rectangle2D r=new Rectangle2D.Double();
107
                if (isCorrectSize(tolerance,layout.getLayoutControl().getFirstPoint(),layout.getLayoutControl().getLastPoint())){
108
                        Point2D fp=layout.getLayoutControl().getFirstPoint();
109
                        Point2D lp=layout.getLayoutControl().getLastPoint();
110
                        if (fp.getX()<lp.getX()){
111
                                if (fp.getY()<lp.getY()){
112
                                        r.setRect(fp.getX(),fp.getY(),lp.getX()-fp.getX(),lp.getY()-fp.getY());
113
                                }else{
114
                                        r.setRect(fp.getX(),lp.getY(),lp.getX()-fp.getX(),fp.getY()-lp.getY());
115
                                }
116
                        }else{
117
                                if (fp.getY()>lp.getY()){
118
                                        r.setRect(lp.getX(),lp.getY(),fp.getX()-lp.getX(),fp.getY()-lp.getY());
119
                                }else{
120
                                        r.setRect(lp.getX(),fp.getY(),lp.getX()-fp.getX(),lp.getY()-fp.getY());
121
                                }
122
                        }
123
                }else{
124
                        Point2D p1=layout.getLayoutControl().getFirstPoint();
125
                        p1=new Point2D.Double(p1.getX()+tolerance,p1.getY()+tolerance);
126
                        r.setFrameFromDiagonal(layout.getLayoutControl().getFirstPoint(),p1);
127
                }
128
                return r;
129
        }
130
        /**
131
         * Devuelve true si el rectangulo formado por los dos puntos que se pasan
132
         * como par?metro es superior a la tolerancia.
133
         *
134
         * @param tolerance Tolerancia
135
         * @param p1 Punto inicial del rect?ngulo.
136
         * @param p2 Punto final del rect?ngulo.
137
         *
138
         * @return True si el tama?o es correcto.
139
         */
140
        private boolean isCorrectSize(int tolerance, Point2D p1, Point2D p2) {
141
                if (Math.abs(p2.getX()-p1.getX())<tolerance) {
142
                        return false;
143
                } else if (Math.abs(p2.getY()-p1.getY())<tolerance) {
144
                        return false;
145
                }
146
                return true;
147
        }
148
}