Statistics
| Revision:

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

History | View | Annotate | Download (4.2 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.exceptions.expansionfile.ExpansionFileReadException;
49
import com.iver.cit.gvsig.fmap.MapControl;
50
import com.iver.cit.gvsig.fmap.ViewPort;
51
import com.iver.cit.gvsig.fmap.layers.FLayer;
52
import com.iver.cit.gvsig.fmap.layers.FLayers;
53
import com.iver.cit.gvsig.fmap.tools.SelectImageListenerImpl;
54
import com.iver.cit.gvsig.fmap.tools.Events.PointEvent;
55

    
56

    
57
/**
58
* Extensi?n de la clase SelectImageListenerImple de FMap. Esta clase
59
* permite capturar el evento de la selecci?n de un punto sobre la vista
60
* . Controlara que capa de la pila que est? visible cae dentro del punto
61
* seleccionado poniendo esta capa como activa. En caso de que haya varias
62
* capas visibles sobre ese punto, pondr? como activa la capa superior.
63
*
64
* @author Nacho Brodin <brodin_ign@gva.es>
65
*/
66
public class SelectImageListener extends SelectImageListenerImpl {
67

    
68
        //FLyrRaster                         layer = null;
69
        Rectangle2D extentLayer = null;
70
        /**
71
         * Contructor
72
         * @param mapCtrl
73
         */
74
        public SelectImageListener(MapControl mapCtrl) {
75
                super(mapCtrl);
76
        }
77

    
78

    
79
        /* (non-Javadoc)
80
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.PointListener#point(com.iver.cit.gvsig.fmap.tools.Events.PointEvent)
81
         */
82
        public void point(PointEvent event) {
83
                super.point(event);
84

    
85
                Point2D pointSelect = event.getPoint();
86

    
87
                if (PluginServices.getMainFrame() != null)
88
                    PluginServices.getMainFrame().enableControls();
89

    
90
                ViewPort vp = mapCtrl.getMapContext().getViewPort();
91

    
92
                wcPoint = vp.toMapPoint((int)pointSelect.getX(), (int)pointSelect.getY());
93

    
94
                FLayers layers = mapCtrl.getMapContext().getLayers();
95
                for(int i=0;i<layers.getLayersCount();i++)
96
                        layers.getLayer(i).setActive(false);
97

    
98
                boolean firstLayer = false;
99

    
100
                for(int i=layers.getLayersCount()-1;i>=0;i--){
101
                        if (select(layers.getLayer(i),i)) break;
102
                }
103
        }
104

    
105
        private boolean select(FLayer layer,int pos){
106
                if (layer instanceof FLayers){
107
                        FLayers laux=(FLayers)layer;
108
                        for (int j=laux.getLayersCount()-1;j>=0;j--){
109
                                if (select(laux.getLayer(j),j)){
110
                                        return true;
111
                                }
112
                        }
113
                }else{
114
                try{
115
                        extentLayer = layer.getFullExtent();
116
                }catch(ReadDriverException exc){
117
                        exc.printStackTrace();
118
                } catch (ExpansionFileReadException e) {
119
                        e.printStackTrace();
120
                }
121
/*
122
                if(        extentLayer.getMaxX() >= wcPoint.getX() &&
123
                        extentLayer.getMinX() <= wcPoint.getX() &&
124
                        extentLayer.getMaxY() >= wcPoint.getY() &&
125
                        extentLayer.getMinY() <= wcPoint.getY() &&
126
                        layer.isVisible() &&
127
                        layer instanceof FLyrRaster){
128
                        layer.setActive(true);
129
                        View view = (View) PluginServices.getMDIManager().getActiveWindow();
130
                        JScrollBar verticalBar = view.getTOC().getJScrollPane().getVerticalScrollBar();
131
                        double widthPerEntry = verticalBar.getMaximum()/layer.getMapContext().getLayers().getLayersCount();
132
                        verticalBar.setValue((int)widthPerEntry*(layer.getMapContext().getLayers().getLayersCount()-pos-1));
133
                        return true;
134
                }
135
*/
136
                }
137
                return false;
138
        }
139
}