Statistics
| Revision:

svn-gvsig-desktop / trunk / extensions / extGeoreferencing / src / com / iver / cit / gvsig / fmap / tools / Behavior / GeoMoveBehavior.java @ 5550

History | View | Annotate | Download (12.4 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.fmap.tools.Behavior;
42

    
43
import java.awt.Color;
44
import java.awt.Component;
45
import java.awt.Cursor;
46
import java.awt.Graphics;
47
import java.awt.Image;
48
import java.awt.Point;
49
import java.awt.Rectangle;
50
import java.awt.Toolkit;
51
import java.awt.event.MouseEvent;
52
import java.awt.event.MouseWheelEvent;
53
import java.awt.geom.Point2D;
54
import java.awt.image.BufferedImage;
55

    
56
import javax.swing.ImageIcon;
57
import javax.swing.JOptionPane;
58

    
59
import org.cresques.px.Extent;
60
import org.gvsig.georeferencing.gui.dialogs.GeoreferencingDialog;
61

    
62
import com.iver.andami.PluginServices;
63
import com.iver.cit.gvsig.fmap.MapControl;
64
import com.iver.cit.gvsig.fmap.ViewPort;
65
import com.iver.cit.gvsig.fmap.layers.FLayer;
66
import com.iver.cit.gvsig.fmap.layers.FLyrGeoRaster;
67
import com.iver.cit.gvsig.fmap.layers.GeoPoint;
68
import com.iver.cit.gvsig.fmap.tools.BehaviorException;
69
import com.iver.cit.gvsig.fmap.tools.Behavior.Behavior;
70
import com.iver.cit.gvsig.fmap.tools.Listeners.PanListener;
71
import com.iver.cit.gvsig.fmap.tools.Listeners.ToolListener;
72

    
73

    
74
/**
75
 * Behaviour que espera un listener de tipo GeoMoveListener.
76
 * Nacho Brodin (brodin_ign@gva.es)
77
 *
78
 */
79
public class GeoMoveBehavior extends Behavior {
80
        
81
        private final Image defaultCursor = new ImageIcon(MapControl.class.getResource(
82
        "images/CruxCursor.png")).getImage();
83
        private final Image handCursor = new ImageIcon(MapControl.class.getResource(
84
        "images/Hand.gif")).getImage();
85

    
86
        private Cursor                                                         cur = null;        
87
        private FLyrGeoRaster                                         lyrGeoRaster = null;
88
        private boolean                                                 isMoveable = false;
89
        
90
        /**
91
         * Variable booleana que est? a true si el cursor por defecto est? 
92
         * activo y a false si hay otro.
93
         */
94
        private boolean                                                 defaultCursorActive = true;
95
        
96
        /**
97
         * Puntos de inicio y final para el arrastre de la imagen.
98
         */
99
        private Point2D                                                 ptoIni = null;
100
        private Point2D                                                 ptoFin = null;
101
        private com.iver.cit.gvsig.gui.View         theView = null;
102
        private PanListener                                         listener;
103
                
104
        /**
105
         * Crea un nuevo RectangleBehavior.
106
         *
107
         * @param zili listener.
108
         */
109
        public GeoMoveBehavior(PanListener zili) {
110
                listener = zili;
111
                cur = zili.getCursor();
112
        }
113
        
114
        /**
115
         * Funci?n que carga la capa si todav?a no lo est?.
116
         */
117
        private void loadLayer() throws InstantiationException, ClassCastException{
118
                //Cargamos la capa
119
                
120
                theView = (com.iver.cit.gvsig.gui.View) PluginServices.getMDIManager().getActiveView();
121
                for(int i=0;i<theView.getMapControl().getMapContext().getLayers().getLayersCount();i++){
122
                        FLayer lyr = theView.getMapControl().getMapContext().getLayers().getLayer(i);
123
                        if(        lyr instanceof FLyrGeoRaster && 
124
                                lyr.getName().startsWith("*") &&
125
                                lyr.isActive())
126
                                this.lyrGeoRaster = (FLyrGeoRaster)lyr;
127
                }
128
                if(lyrGeoRaster == null)
129
                        throw new InstantiationException("No se ha podido cargar la capa de georreferenciaci?n");
130
        }
131
        
132
        /**
133
         * Coloca el cursor del rat?n con el icono adecuado cuando entra dentro de la 
134
         * imagen.
135
         */
136
        public void mouseMoved(MouseEvent e) throws BehaviorException {
137
                
138
                ViewPort vp = getMapControl().getMapContext().getViewPort();
139
                
140
                try{
141
                        loadLayer();
142
                        
143
                        Point2D pto = vp.toMapPoint(e.getX(), e.getY());
144
                                
145
                        if(        pto.getX() > lyrGeoRaster.getAssignExtent().getMin().getX() &&
146
                                pto.getX() < lyrGeoRaster.getAssignExtent().getMax().getX() &&
147
                                pto.getY() > lyrGeoRaster.getAssignExtent().getMin().getY() &&
148
                                pto.getY() < lyrGeoRaster.getAssignExtent().getMax().getY()){
149
                                if(defaultCursorActive){
150
                                        getMapControl().setCursor(Toolkit.getDefaultToolkit().createCustomCursor(handCursor,
151
                                                new Point(16, 16), ""));
152
                                        defaultCursorActive = false;
153
                                }
154
                        }else{
155
                                if(!defaultCursorActive){
156
                                        getMapControl().setCursor(Toolkit.getDefaultToolkit().createCustomCursor(defaultCursor,
157
                                                new Point(16, 16), ""));
158
                                        defaultCursorActive = true;
159
                                }
160
                        }
161
                }catch(InstantiationException exc){
162
                        JOptionPane.showMessageDialog((Component)PluginServices.getMainFrame(),
163
                                        PluginServices.getText(this, "error_capa_puntos"));
164
                }catch(ClassCastException exc){
165
                        JOptionPane.showMessageDialog((Component)PluginServices.getMainFrame(),
166
                                        PluginServices.getText(this, "error_capa_puntos"));
167
                }
168
                
169
        }
170
        
171
        /**
172
         * Obtiene el cursor actual
173
         */
174
        public Cursor getCursor() {
175
                return this.cur;
176
        }
177
        
178
        /**
179
         * Si no est? activo el cursor por defecto capturamos el punto 
180
         * seleccionado en coordenadas del mundo real.
181
         */
182
        public void mousePressed(MouseEvent e) throws BehaviorException {
183
                if(e.getButton() == MouseEvent.BUTTON1 && !defaultCursorActive){
184
                        
185
                        try{
186
                                loadLayer();
187
                        }catch(InstantiationException exc){
188
                                JOptionPane.showMessageDialog((Component)PluginServices.getMainFrame(),
189
                                                PluginServices.getText(this, "error_capa_puntos"));
190
                                return;
191
                        }catch(ClassCastException exc){
192
                                JOptionPane.showMessageDialog((Component)PluginServices.getMainFrame(),
193
                                                PluginServices.getText(this, "error_capa_puntos"));
194
                                return;
195
                        }
196
                        
197
                        ViewPort vp = getMapControl().getMapContext().getViewPort();
198
                        ptoIni = vp.toMapPoint(e.getPoint());
199
                        
200
                        //Cargamos la imagen de arrastre
201
/*                        Point2D ul = vp.fromMapPoint(lyrGeoRaster.getAssignExtent().getMin().getX(), 
202
                                                                                lyrGeoRaster.getAssignExtent().getMin().getY());
203
                        Point2D lr = vp.fromMapPoint(lyrGeoRaster.getAssignExtent().getMax().getX(), 
204
                                                                                lyrGeoRaster.getAssignExtent().getMax().getY());
205
                                                
206
                        double ulx = 0D, uly = 0D, lrx = 0D, lry = 0D;
207
                        if(ul.getX() > vp.getExtent().getMinX())
208
                                ulx = ul.getX();
209
                        else
210
                                ulx = vp.getExtent().getMinX();
211
                        
212
                        if(ul.getY() > vp.getExtent().getMinY())
213
                                uly = ul.getY();
214
                        else
215
                                uly = vp.getExtent().getMinY();
216
                        
217
                        if(lr.getX() < vp.getExtent().getMaxX())
218
                                lrx = lr.getX();
219
                        else
220
                                lrx = vp.getExtent().getMaxX();
221
                        
222
                        if(lr.getY() < vp.getExtent().getMaxY())
223
                                lry = lr.getY();
224
                        else
225
                                lry = vp.getExtent().getMaxY();
226
                        
227
                        BufferedImage img = getMapControl().getImage();
228
                        System.out.println("-->"+img.getMinX()+" "+img.getMinY()+" "+img.getWidth()+" "+img.getHeight());
229
                        Rectangle r = new Rectangle((int)ulx, (int)uly, (int)Math.abs(lrx-ulx), (int)Math.abs(lry-uly));
230
                        System.out.println("--->"+ulx+" "+uly+" "+lrx+" "+lry);
231
                        Raster raster = img.getData(r);
232
                        miniGeoRaster.setData(raster);*/
233
                        /*miniGeoRaster = new BufferedImage((int)Math.abs(lrx-ulx), (int)Math.abs(lry-uly), BufferedImage.TYPE_INT_ARGB);
234
                        int[] rasterData = new int[r.width * r.height * 100];
235
                        rasterData = img.getRGB(r.x, r.y, r.width, r.height, rasterData, 0, r.width);
236
                        miniGeoRaster.setRGB(0, 0, r.width, r.height, rasterData, 0, r.width);*/
237

    
238
                        
239
                        isMoveable = true;
240
                }                
241
        }
242
        
243
        /**
244
         *  Cuando soltamos el bot?n del rat?n desplazamos la imagen a la posici?n
245
         * de destino calculando el extent nuevamente.
246
         */
247
        public void mouseReleased(MouseEvent e) throws BehaviorException {
248
                if(e.getButton() == MouseEvent.BUTTON1 && isMoveable){
249
                        
250
                        ViewPort vp = getMapControl().getMapContext().getViewPort();
251
                        ptoFin = vp.toMapPoint(e.getPoint());
252
                        double distX = ptoFin.getX() - ptoIni.getX();
253
                        double distY = ptoFin.getY() - ptoIni.getY();
254
                        if(this.lyrGeoRaster != null){
255
                                Extent ext = new Extent(lyrGeoRaster.getAssignExtent().getMin().getX() + distX, 
256
                                                lyrGeoRaster.getAssignExtent().getMin().getY() + distY,
257
                                                lyrGeoRaster.getAssignExtent().getMax().getX() + distX, 
258
                                                lyrGeoRaster.getAssignExtent().getMax().getY() + distY);
259
                        
260
                                //Asignamos el nuevo extent a la capa
261
                                ((FLyrGeoRaster)getMapControl().getMapContext().getLayers().getLayer(lyrGeoRaster.getName())).setAssignExtent(ext);
262
                                
263
                                //Si la capa tiene puntos de control actualizamos el punto que tiene coordenadas
264
                                //en pixeles de la imagen.
265
                                for(int i=0; i<lyrGeoRaster.getFLyrPoints().getCountPoints(); i++){
266
                                        Point2D center = lyrGeoRaster.img2World(lyrGeoRaster.getFLyrPoints().getPoint(i).pixelPoint);
267
                                        lyrGeoRaster.getFLyrPoints().setMiniExtent(        i,
268
                                                                                                                                center,
269
                                                                                                                                lyrGeoRaster.getGeoDialog().getLeftInitViewport(vp, center, lyrGeoRaster.getFLyrPoints().getPoint(i).leftViewPort, 1),
270
                                                                                                                                false);
271
                                        if(i == lyrGeoRaster.getGeoDialog().getSelectedPoint()){
272
                                                lyrGeoRaster.updateData(i + 1, lyrGeoRaster.getFLyrPoints().getPoint(i).pixelPoint, null, theView);
273
                                                theView.getMapControl().getMapContext().invalidate();
274
                                        }
275
                                }
276
                                                        
277
                        }
278
                        isMoveable = false;
279
                }
280
                this.lyrGeoRaster = null;
281
        }
282
        
283
        /**
284
         * Funci?n de pintado del canvas.Pintamos un marco a la imagen para saber 
285
         * donde la movemos. 
286
         */
287
        public void paintComponent(Graphics g) {
288
                super.paintComponent(g);
289
                if(isMoveable){
290
                        BufferedImage img = getMapControl().getImage();
291
                        
292
                        ViewPort vp = getMapControl().getMapContext().getViewPort();
293
        
294
                        Rectangle r = new Rectangle();
295
                        
296
                        Point2D ul = vp.fromMapPoint(lyrGeoRaster.getAssignExtent().getMin().getX(), 
297
                                                                                 lyrGeoRaster.getAssignExtent().getMin().getY());
298
                        Point2D lr = vp.fromMapPoint(lyrGeoRaster.getAssignExtent().getMax().getX(), 
299
                                                                                 lyrGeoRaster.getAssignExtent().getMax().getY());
300
                        r.setFrameFromDiagonal(ul, lr);
301
                        
302
                        Point2D ini = vp.fromMapPoint(ptoIni.getX() , ptoIni.getY());
303
                        Point2D fin = vp.fromMapPoint(ptoFin.getX() , ptoFin.getY());
304
                        
305
                        double distX = fin.getX() - ini.getX();
306
                        double distY = fin.getY() - ini.getY();
307
                        
308
                        g.drawImage(img, 0, 0, null);
309
                        g.setColor(Color.red);
310
        
311
                        //g.drawImage(miniGeoRaster, r.x + (int)distX, r.y + (int)distY, null);
312
                        g.drawRect(r.x + (int)distX, r.y + (int)distY, r.width, r.height);
313
                }
314
        }
315
        
316
        /**
317
         * Esta funci?n repinta el canvas si se est? arrasrtando la imagen para
318
         * poder ver el marco de arrastre.
319
         */
320
        public void mouseDragged(MouseEvent e) throws BehaviorException {
321
                if(isMoveable){
322
                        ViewPort vp = getMapControl().getMapContext().getViewPort();
323
                        ptoFin = vp.toMapPoint(e.getPoint());
324
                        getMapControl().repaint();
325
                }
326
        }
327
        
328
        /* (non-Javadoc)
329
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#getListener()
330
         */
331
        public ToolListener getListener() {
332
                // TODO Auto-generated method stub
333
                return null;
334
        }
335
        /* (non-Javadoc)
336
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#getMapControl()
337
         */
338
        public MapControl getMapControl() {
339
                // TODO Auto-generated method stub
340
                return super.getMapControl();
341
        }
342
        /* (non-Javadoc)
343
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#mouseClicked(java.awt.event.MouseEvent)
344
         */
345
        public void mouseClicked(MouseEvent e) throws BehaviorException {
346
                // TODO Auto-generated method stub
347
                super.mouseClicked(e);
348
        }
349

    
350
        /* (non-Javadoc)
351
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#mouseEntered(java.awt.event.MouseEvent)
352
         */
353
        public void mouseEntered(MouseEvent e) throws BehaviorException {
354
                // TODO Auto-generated method stub
355
                super.mouseEntered(e);
356
        }
357
        /* (non-Javadoc)
358
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#mouseExited(java.awt.event.MouseEvent)
359
         */
360
        public void mouseExited(MouseEvent e) throws BehaviorException {
361
                // TODO Auto-generated method stub
362
                super.mouseExited(e);
363
        }
364

    
365
        /* (non-Javadoc)
366
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#mouseWheelMoved(java.awt.event.MouseWheelEvent)
367
         */
368
        public void mouseWheelMoved(MouseWheelEvent e) throws BehaviorException {
369
                // TODO Auto-generated method stub
370
                super.mouseWheelMoved(e);
371
        }
372

    
373
        /* (non-Javadoc)
374
         * @see com.iver.cit.gvsig.fmap.tools.Behavior.Behavior#setMapControl(com.iver.cit.gvsig.fmap.MapControl)
375
         */
376
        public void setMapControl(MapControl mc) {
377
                // TODO Auto-generated method stub
378
                super.setMapControl(mc);
379
        }
380

    
381
}