Statistics
| Revision:

root / branches / v2_0_0_prep / libraries / libFMap_controls / src / org / gvsig / fmap / mapcontrol / tools / PolygonSelectionListener.java @ 36684

History | View | Annotate | Download (5.92 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 org.gvsig.fmap.mapcontrol.tools;
42

    
43
import java.awt.Image;
44

    
45
import javax.swing.ImageIcon;
46

    
47
import org.gvsig.fmap.dal.exception.DataException;
48
import org.gvsig.fmap.dal.feature.FeatureSelection;
49
import org.gvsig.fmap.dal.feature.FeatureSet;
50
import org.gvsig.fmap.dal.feature.exception.CreateGeometryException;
51
import org.gvsig.fmap.geom.Geometry;
52
import org.gvsig.fmap.geom.GeometryLocator;
53
import org.gvsig.fmap.geom.GeometryManager;
54
import org.gvsig.fmap.geom.Geometry.SUBTYPES;
55
import org.gvsig.fmap.geom.Geometry.TYPES;
56
import org.gvsig.fmap.geom.primitive.GeneralPathX;
57
import org.gvsig.fmap.geom.primitive.Surface;
58
import org.gvsig.fmap.mapcontext.layers.FLayer;
59
import org.gvsig.fmap.mapcontext.layers.vectorial.FLyrVect;
60
import org.gvsig.fmap.mapcontrol.MapControl;
61
import org.gvsig.fmap.mapcontrol.tools.Events.MeasureEvent;
62
import org.gvsig.fmap.mapcontrol.tools.Listeners.PolylineListener;
63
import org.gvsig.tools.dispose.DisposeUtils;
64
import org.slf4j.Logger;
65
import org.slf4j.LoggerFactory;
66

    
67
/**
68
 * <p>Listener that selects all features of the active and vector layers which intersect with the defined
69
 *  polygon area in the associated {@link MapControl MapControl} object.</p>
70
 *
71
 * <p>The selection will be produced after user finishes the creation of the polyline.</p>
72
 *
73
 * @author Vicente Caballero Navarro
74
 */
75
public class PolygonSelectionListener implements PolylineListener {
76
        private static final GeometryManager geomManager = GeometryLocator.getGeometryManager();
77
        private static final Logger logger = LoggerFactory.getLogger(PolygonSelectionListener.class);
78
        /**
79
         * The image to display when the cursor is active.
80
         */
81
        private final Image img = new ImageIcon(MapControl.class.getClassLoader().getResource(
82
                                "org/gvsig/fmap/mapcontrol/images/PoligonCursor.png")).getImage();
83
        
84
        /**
85
         * The cursor used to work with this tool listener.
86
         *
87
         * @see #getCursor()
88
         */
89
        private MapControl mapCtrl;
90

    
91
        /**
92
          * <p>Creates a new <code>PolygonSelectionListener</code> object.</p>
93
         *
94
         * @param mc the <code>MapControl</code> where is drawn the polyline
95
         */
96
        public PolygonSelectionListener(MapControl mc) {
97
                this.mapCtrl = mc;
98
        }
99

    
100
        /*
101
         * (non-Javadoc)
102
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.ToolListener#getImageCursor()
103
         */
104
        public Image getImageCursor() {
105
                return img;
106
        }
107

    
108
        /*
109
         * (non-Javadoc)
110
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.ToolListener#cancelDrawing()
111
         */
112
        public boolean cancelDrawing() {
113
                return false;
114
        }
115

    
116
        /*
117
         * (non-Javadoc)
118
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.PolylineListener#points(com.iver.cit.gvsig.fmap.tools.Events.MeasureEvent)
119
         */
120
        public void points(MeasureEvent event) throws BehaviorException {
121
                // TODO Auto-generated method stub
122

    
123
        }
124

    
125
        /*
126
         * (non-Javadoc)
127
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.PolylineListener#points(com.iver.cit.gvsig.fmap.tools.Events.MeasureEvent)
128
         */
129
        public void pointFixed(MeasureEvent event) throws BehaviorException {
130
                // TODO Auto-generated method stub
131

    
132
        }
133

    
134
        /*
135
         * (non-Javadoc)
136
         * @see com.iver.cit.gvsig.fmap.tools.Listeners.PolylineListener#polylineFinished(com.iver.cit.gvsig.fmap.tools.Events.MeasureEvent)
137
         */
138
        public void polylineFinished(MeasureEvent event) throws BehaviorException {
139
                try {
140
                        GeometryManager geomManager = GeometryLocator.getGeometryManager();
141

    
142
            GeneralPathX gp = event.getGP();
143
            Surface geom = (Surface)geomManager.create(TYPES.SURFACE, SUBTYPES.GEOM2D);
144
            geom.setGeneralPath(gp);           
145
            FLayer[] actives = mapCtrl.getMapContext()
146
                .getLayers().getActives();
147
            for (int i=0; i < actives.length; i++)
148
            {
149
                if (actives[i] instanceof FLyrVect) {
150
                    FLyrVect lyrVect = (FLyrVect) actives[i];
151
                    FeatureSelection oldSelection = (FeatureSelection)lyrVect.getFeatureStore().getSelection();
152
                                        FeatureSet newSelection = null;
153
                                        try {
154
                                                newSelection =
155
                                                                lyrVect.queryByGeometry(geom,
156
                                                                                lyrVect.getFeatureStore()
157
                                                                                                .getDefaultFeatureType());
158
                                                if (event.getEvent().isControlDown()) {
159
                                                        oldSelection.select(newSelection);
160
                                                } else {
161
                                                        lyrVect.getDataStore().setSelection(newSelection);
162
                                                }
163
                                        } finally {
164
                                                DisposeUtils.dispose(newSelection);
165
                    }
166
                }
167
            }
168

    
169
                } catch (DataException e) {
170
                        throw new BehaviorException("No se pudo hacer la selecci?n", e);
171
                } catch (org.gvsig.fmap.geom.exception.CreateGeometryException e) {
172
                        throw new BehaviorException("No se pudo hacer la selecci?n", 
173
                                        new CreateGeometryException(TYPES.SURFACE, SUBTYPES.GEOM2D, e));
174
                }
175
        }
176
}