Statistics
| Revision:

gvsig-raster / org.gvsig.raster.georeferencing / trunk / org.gvsig.raster.georeferencing / org.gvsig.raster.georeferencing.swing / org.gvsig.raster.georeferencing.swing.impl / src / main / java / org / gvsig / raster / georeferencing / swing / impl / view / ViewPanelImpl.java @ 1711

History | View | Annotate | Download (9.03 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
package org.gvsig.raster.georeferencing.swing.impl.view;
23

    
24
import java.awt.BorderLayout;
25
import java.awt.event.ComponentEvent;
26
import java.awt.event.ComponentListener;
27
import java.awt.geom.Point2D;
28
import java.awt.geom.Rectangle2D;
29
import java.awt.image.BufferedImage;
30

    
31
import org.gvsig.raster.georeferencing.swing.impl.layer.ZoomCursorGraphicLayer;
32
import org.gvsig.raster.georeferencing.swing.view.IExtensionRequest;
33
import org.gvsig.raster.georeferencing.swing.view.IGraphicLayer;
34
import org.gvsig.raster.georeferencing.swing.view.ToolListener;
35
import org.gvsig.raster.georeferencing.swing.view.ViewListener;
36
import org.slf4j.LoggerFactory;
37

    
38
/**
39
 * Panel que contiene el panel con la vista a georreferenciar
40
 * 
41
 * 22/12/2007
42
 * @author Nacho Brodin (nachobrodin@gmail.com)
43
 */
44
public class ViewPanelImpl extends BaseZoomView implements ComponentListener {
45
        private static final long         serialVersionUID          = 1L;
46
        private ZoomCursorGraphicLayer    zoomCursorGraphic         = null;
47
        private ToolListener              zoomCursorGraphicListener = null;
48
        private boolean                   rightSideButtons          = true;
49
        
50
        /**
51
         * Constructor.
52
         * Crea la composici?n de controles de zoom.
53
         * @param posX Posici?n en X
54
         * @param posY Posici?n en Y
55
         * @param w Tama?o en pixeles de ancho
56
         * @param h Tama?o en pixeles de alto
57
         */
58
        public ViewPanelImpl(ToolListener zoomCursorGraphicListener, boolean rightSideButtons) {
59
                this.zoomCursorGraphicListener = zoomCursorGraphicListener;
60
                this.rightSideButtons = rightSideButtons;
61
                init();
62
        }
63
        
64
        /**
65
         * Inicializaci?n de los componentes gr?ficos
66
         */
67
        private void init() {
68
                setLayout(new BorderLayout());
69
                add(getControl(), BorderLayout.CENTER);
70
                getZoomCursorGraphicLayer();
71
        }
72
        
73
        /**
74
         * Asigna el listener de eventos de la vista
75
         * @param listener
76
         */
77
        public void setViewListener(ViewListener listener) {
78
                getControl().setViewListener(listener);
79
        }
80
        
81
        
82
        /**
83
         * Asigna el valor para el flag minxMaxyUL. Este flag informa de que la esquina 
84
         * superior izquierda corresponde con el valor de m?nimo X y m?ximo Y. En caso 
85
         * de ser false esta esquina ser?a de m?nimo X y m?nimo Y.
86
         * @param v
87
         */
88
        /*public void setMinxMaxyUL(boolean v) {
89
                getCanvas().setMinxMaxyUL(v);
90
        }*/
91
        
92
        /**
93
         * Asigna un nuevo centro de visualizaci?n. Vuelve a realizar la petici?n
94
         * @param center
95
         */
96
        public void setCenter(Point2D center) {
97
                //TODO: Calcular las coordenadas del cursor gr?fico
98
                getControl().setCenter(center);
99
        }
100
        
101
        /**
102
         * Asigna los par?metros de dibujado para el raster
103
         * @param img Buffer con un ?rea de datos
104
         * @param ext Rectangle2D del ?rea de datos dada 
105
         * @param pixelSize Tama?o de pixel
106
         * @param center Punto del ?rea de datos donde se quiere centrar el dibujado del buffer
107
         */
108
        public void setDrawParams(BufferedImage img, Rectangle2D ext, double pixelSize, Point2D center) {
109
                getControl().setDrawParams(img, ext, pixelSize, center) ;
110
        }
111
        
112
        /**
113
         * Obtiene el panel de control de zoom de coordenadas pixel
114
         * @return
115
         */
116
        public ViewControl getControl() {
117
                if(zoomPixelControl == null) {
118
                        if(rightSideButtons)
119
                                zoomPixelControl = new ViewControl(ViewControl.RIGHT_CONTROL);
120
                        else 
121
                                zoomPixelControl = new ViewControl(ViewControl.LEFT_CONTROL);
122
                        zoomPixelControl.addComponentListener(this);
123
                }
124
                return zoomPixelControl;
125
        }
126
        
127
        /**
128
         * Registra un objeto IExtensionRequest para que no se aplique un escalado sobre
129
         * el buffer pasado por par?metro. Alternativamente a la aplicaci?n de este escalado
130
         * se ejecutar? el m?todo request del interfaz para que el cliente pueda pasar un 
131
         * nuevo buffer con escala 1:1 y con la extensi?n correspondiente al zoom.
132
         * @param er
133
         */
134
        public void setRequestListener(IExtensionRequest er) {
135
                zoomPixelControl.setExtensionRequest(er);
136
        }
137
        
138
        /*
139
         * (non-Javadoc)
140
         * @see org.gvsig.rastertools.georeferencing.view.BaseZoomView#addGraphicLayer(org.gvsig.rastertools.georeferencing.ui.zoom.IGraphicLayer)
141
         */
142
        public void addGraphicLayer(IGraphicLayer graphicLayer) {
143
                getControl().setGraphicLayer(graphicLayer);
144
        }
145
                
146
        /**
147
         * Obtiene el la capa gr?fica con la ventana de zoom
148
         * @return
149
         */
150
        public ZoomCursorGraphicLayer getZoomCursorGraphicLayer() {
151
                if(zoomCursorGraphic == null) {
152
                        zoomCursorGraphic = new ZoomCursorGraphicLayer(getWidth() / 2, getHeight() / 2, 12, 6, zoomCursorGraphicListener);
153
                        zoomCursorGraphic.setCanvas(getControl().getCanvas());
154
                        getControl().setGraphicLayer(zoomCursorGraphic);
155
                }
156
                return zoomCursorGraphic;
157
        }
158
        
159
        /**
160
         * Asigna la posici?n del cursor en el canvas
161
         * @param x Posici?n en X
162
         * @param y Posici?n en Y
163
         */
164
        public void setCursorPosition(int x, int y) {
165
                getZoomCursorGraphicLayer().setCursorPosition(x, y);
166
        }
167
        
168
        /**
169
         * Asigna el tama?o del cursor en pixeles del canvas
170
         * @param w Ancho
171
         * @param h Alto
172
         */
173
        public void setCursorSize(int w, int h) {
174
                getZoomCursorGraphicLayer().setCursorSize(w, h);
175
        }
176
                
177
        /**
178
         * Activa o desactiva el mostrado de informaci?n
179
         * @param showInfo
180
         */
181
        public void setShowInfo(boolean show) {
182
                zoomPixelControl.getCanvas().setShowInfo(show);
183
        }
184
                
185
        /**
186
         * Obtiene las coordenadas de la ventana de zoom. Las coordenadas son devueltas
187
         * en referencia a las coordenadas del mundo. 
188
         * @return
189
         */
190
        public Rectangle2D getCursorWorldCoordinates() {
191
                Rectangle2D r = getZoomCursorGraphicLayer().getCursorViewCoordinates();
192
                Point2D p1 = zoomPixelControl.getCanvas().viewCoordsToWorld(new Point2D.Double(r.getX(), r.getY()));
193
                Point2D p2 = zoomPixelControl.getCanvas().viewCoordsToWorld(new Point2D.Double(r.getX() + r.getWidth(), r.getY() + r.getHeight()));
194
                return new Rectangle2D.Double(        Math.min(p1.getX(), p2.getX()), 
195
                                                                                Math.max(p1.getY(), p2.getY()), 
196
                                                                                Math.abs(p2.getX() - p1.getX()), 
197
                                                                                Math.abs(p2.getY() - p1.getY()));
198
        }
199
        
200
        /**
201
         * Obtiene las coordenadas de la ventana de zoom. Las coordenadas son devueltas
202
         * en referencia a las coordenadas del mundo. Esta llamada ajusta el tama?o de la ventana a la 
203
         * proporci?n pasada por par?metro. Es decir, si pasamos una proporci?n en la que el ancho es 3 veces 
204
         * mayor que el alto se ajustar? el zoom a esta proporci?n ya que presupone que la ventana de
205
         * destino del zoom va a tener esas proporciones.
206
         * @return
207
         */
208
        public Rectangle2D getCursorAdjustedWorldCoordinates(int wWindow, int hWindow) {
209
                Rectangle2D r = getZoomCursorGraphicLayer().getCursorViewCoordinates();
210
                double x = r.getX(), y = r.getY(), w = r.getWidth(), h = r.getHeight();
211
                
212
                try {
213
                        if(wWindow < hWindow) { //Si la de destino es m?s alta que ancha
214
                                if((r.getWidth() / r.getHeight()) >= (wWindow / hWindow)) {
215
                                        h = (hWindow * r.getWidth()) / wWindow;
216
                                        y = r.getCenterY() - (h / 2);
217
                                } else {
218
                                        w = (wWindow * r.getHeight()) / hWindow;
219
                                        x = r.getCenterX() - (w / 2);
220
                                }
221
                        } else { //Si la de destino es m?s ancha que alta
222
                                if((r.getWidth() / r.getHeight()) <= (wWindow / hWindow)) {
223
                                        w = (wWindow * r.getHeight()) / hWindow;
224
                                        x = r.getCenterX() - (w / 2);
225
                                } else {
226
                                        h = (hWindow * r.getWidth()) / wWindow;
227
                                        y = r.getCenterY() - (h / 2);
228
                                }
229
                        }
230
                }catch(ArithmeticException ex) {
231
                        LoggerFactory.getLogger(ViewPanelImpl.class).debug("Redimensi?n de las ventanas. La altura de estas es menor que cero", this, ex);
232
                        return r;
233
                }
234
                //if(zoomPixelControl.getCanvas().getMinxMaxyUL())
235
                        r = new Rectangle2D.Double(x, y + h, w, h);
236
                //else
237
                        //r = new Rectangle2D.Double(x, y - h, w, h);
238
                Point2D p1 = zoomPixelControl.getCanvas().viewCoordsToWorld(new Point2D.Double(r.getX(), r.getY()));
239
                Point2D p2 = zoomPixelControl.getCanvas().viewCoordsToWorld(new Point2D.Double(r.getX() + r.getWidth(), r.getY() + r.getHeight()));
240
                return new Rectangle2D.Double(        Math.min(p1.getX(), p2.getX()), 
241
                                                                                Math.max(p1.getY(), p2.getY()), 
242
                                                                                Math.abs(p2.getX() - p1.getX()), 
243
                                                                                Math.abs(p2.getY() - p1.getY()));
244
        }
245
        
246
        /**
247
         * Obtiene el extent del canvas en coordenadas del mundo real
248
         * @return Rectangle2D
249
         */
250
        public Rectangle2D getViewExtent() {
251
                return zoomPixelControl.getCanvas().getExtent();
252
        }
253

    
254
        public void componentHidden(ComponentEvent e) {
255
        }
256

    
257
        public void componentMoved(ComponentEvent e) {
258
        }
259

    
260
        public void componentResized(ComponentEvent e) {
261
                zoomPixelControl.reload();
262
        }
263

    
264
        public void componentShown(ComponentEvent e) {
265
        }
266

    
267
}
268