Statistics
| Revision:

svn-gvsig-desktop / trunk / applications / appgvSIG / src / com / iver / cit / gvsig / project / documents / view / toolListeners / SelectImageListener.java @ 20098

History | View | Annotate | Download (3.98 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.view.toolListeners;
42

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

    
46
import com.hardcode.gdbms.driver.exceptions.ReadDriverException;
47
import com.iver.andami.PluginServices;
48
import com.iver.cit.gvsig.fmap.MapControl;
49
import com.iver.cit.gvsig.fmap.ViewPort;
50
import com.iver.cit.gvsig.fmap.layers.FLayer;
51
import com.iver.cit.gvsig.fmap.layers.FLayers;
52
import com.iver.cit.gvsig.fmap.tools.SelectImageListenerImpl;
53
import com.iver.cit.gvsig.fmap.tools.Events.PointEvent;
54

    
55

    
56
/**
57
 * <p>Listener to select the upper layer with raster data that has information in the associated <code>MapControl</code> object, down
58
 *  the position selected by a single click of any button of the mouse.</p>
59
 *
60
 * <p>The layer selected will be set as <i>active</i>, and the available controls for managing the data will be updated, enabling and
61
 *  disabling the necessary.</p>
62
 * 
63
 * <p>The status of the other layers will be changed to <i>not active</i>.</p>
64
 *
65
 * @deprecated
66
 * @author Nacho Brodin <brodin_ign@gva.es>
67
 */
68
public class SelectImageListener extends SelectImageListenerImpl {
69

    
70
        //FLyrRaster                         layer = null;
71

    
72
        /**
73
         * Extent of the layer selected.
74
         */
75
        Rectangle2D extentLayer = null;
76

    
77
        /**
78
         * <p>Creates a new <code>SelectImageListener</code> object.</p>
79
         * 
80
         * @param mapCtrl the <code>MapControl</code> where are stored the layers
81
         */
82
        public SelectImageListener(MapControl mapCtrl) {
83
                super(mapCtrl);
84
        }
85

    
86
        /*
87
         *  (non-Javadoc)
88
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.PointListener#point(com.iver.cit.gvsig.fmap.tools.Events.PointEvent)
89
         */
90
        public void point(PointEvent event) {
91
                super.point(event);
92

    
93
                Point2D pointSelect = event.getPoint();
94

    
95
                if (PluginServices.getMainFrame() != null)
96
                    PluginServices.getMainFrame().enableControls();
97

    
98
                ViewPort vp = mapCtrl.getMapContext().getViewPort();
99

    
100
                wcPoint = vp.toMapPoint((int)pointSelect.getX(), (int)pointSelect.getY());
101

    
102
                FLayers layers = mapCtrl.getMapContext().getLayers();
103
                for(int i=0;i<layers.getLayersCount();i++)
104
                        layers.getLayer(i).setActive(false);
105

    
106
                for(int i=layers.getLayersCount()-1;i>=0;i--){
107
                        if (select(layers.getLayer(i))) break;
108
                }
109
        }
110

    
111
        /**
112
         * Determines if the <code>layer</code> is selected at a position starting by the end.
113
         * 
114
         * @param layer kind of layer
115
         * @param pos number of positions starting by the end
116
         * 
117
         * @return <code>true</code> if the <code>layer</code> is selected at a position starting by the end, otherwise <code>false</code>
118
         */
119
        private boolean select(FLayer layer){
120
                if (layer instanceof FLayers){
121
                        FLayers laux=(FLayers)layer;
122
                        for (int j=laux.getLayersCount()-1;j>=0;j--){
123
                                if (select(laux.getLayer(j))){
124
                                        return true;
125
                                }
126
                        }
127
                }else{
128
                        try{
129
                                extentLayer = layer.getFullExtent();
130
                        }catch(ReadDriverException exc){
131
                                exc.printStackTrace();
132
                        }
133
                }
134
                return false;
135
        }
136
}