/[schmitzm]/trunk/src/skrueger/geotools/selection/FeatureMapLayerSelectionSynchronizer.java
ViewVC logotype

Annotation of /trunk/src/skrueger/geotools/selection/FeatureMapLayerSelectionSynchronizer.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 125 - (hide annotations)
Sat May 23 11:33:59 2009 UTC (15 years, 9 months ago) by alfonx
File MIME type: text/plain
File size: 11556 byte(s)
* Just code layout
1 alfonx 97 /**
2     Copyright 2008 Stefan Alfons Krüger
3    
4     atlas-framework - This file is part of the Atlas Framework
5    
6     This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
7     This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
8     You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
9    
10     Diese Bibliothek ist freie Software; Sie dürfen sie unter den Bedingungen der GNU Lesser General Public License, wie von der Free Software Foundation veröffentlicht, weiterverteilen und/oder modifizieren; entweder gemäß Version 2.1 der Lizenz oder (nach Ihrer Option) jeder späteren Version.
11     Diese Bibliothek wird in der Hoffnung weiterverbreitet, daß sie nützlich sein wird, jedoch OHNE IRGENDEINE GARANTIE, auch ohne die implizierte Garantie der MARKTREIFE oder der VERWENDBARKEIT FÜR EINEN BESTIMMTEN ZWECK. Mehr Details finden Sie in der GNU Lesser General Public License.
12     Sie sollten eine Kopie der GNU Lesser General Public License zusammen mit dieser Bibliothek erhalten haben; falls nicht, schreiben Sie an die Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA.
13     **/
14     package skrueger.geotools.selection;
15    
16     import java.beans.PropertyChangeEvent;
17     import java.beans.PropertyChangeListener;
18 alfonx 123 import java.util.Arrays;
19 alfonx 97 import java.util.Collection;
20     import java.util.Vector;
21    
22     import javax.swing.JTable;
23     import javax.swing.ListSelectionModel;
24     import javax.swing.event.ListSelectionListener;
25    
26     import org.geotools.feature.Feature;
27 alfonx 111 import org.geotools.feature.FeatureCollection;
28 alfonx 97 import org.geotools.map.MapLayer;
29 alfonx 123 import org.geotools.styling.FeatureTypeStyle;
30 alfonx 97 import org.geotools.styling.Style;
31 alfonx 101 import org.opengis.filter.Filter;
32     import org.opengis.filter.FilterVisitor;
33 alfonx 97
34     import schmitzm.geotools.gui.JMapPane;
35     import schmitzm.geotools.map.event.FeatureSelectedEvent;
36     import schmitzm.geotools.map.event.JMapPaneEvent;
37     import schmitzm.geotools.map.event.JMapPaneListener;
38     import schmitzm.geotools.styling.StylingUtil;
39 alfonx 104 import schmitzm.lang.LangUtil;
40 alfonx 111 import skrueger.geotools.MapPaneToolBar;
41 alfonx 97 import skrueger.geotools.StyledMapInterface;
42    
43     /**
44     * This class keeps the selection of a (feature) {@link JTable} synchronized
45     * with the {@link StyledLayerSelectionModel} of a layer. This is done by
46     * implementing:
47     * <ul>
48     * <li>a {@link PropertyChangeListener} which listens to the
49     * {@link StyledLayerSelectionModel} and accordingly changes the {@link JTable}
50     * selection</li>
51     * <li>a {@link ListSelectionListener} which listens to the {@link JTable} and
52     * accordingly changes the {@link StyledLayerSelectionModel} selection</li>
53     * </ul>
54     * After creating, the instance of this synchronizer must be added as listener
55     * to both, the {@link StyledLayerSelectionModel} and the table's
56     * {@link ListSelectionModel}.
57     *
58     * @author <a href="mailto:[email protected]">Martin Schmitz</a>
59     * (University of Bonn/Germany)
60     */
61     public class FeatureMapLayerSelectionSynchronizer extends
62 alfonx 106 StyledLayerSelectionModelSynchronizer<StyledFeatureLayerSelectionModel>
63     implements JMapPaneListener {
64 alfonx 111 public static final String SELECTION_STYLING = "SELECTION";
65 alfonx 97 /**
66     * Holds the {@link MapLayer} to keep synchronized with the layer selection
67     * model.
68     */
69     protected final MapLayer mapLayer;
70     protected final StyledMapInterface<?> styledMapLayer;
71     protected final JMapPane mapPane;
72 alfonx 111 private final MapPaneToolBar toolBar;
73 alfonx 97
74     /**
75     * Creates a new synchronizer
76     *
77     * @param layerSelModel
78     * layer selection model to keep synchronized with the
79     * {@link MapLayer}
80     *
81     * @param mapLayer
82     * {@link MapLayer} to keep synchronized with.
83     */
84     public FeatureMapLayerSelectionSynchronizer(
85     StyledFeatureLayerSelectionModel layerSelModel,
86     StyledMapInterface<?> styledMapLayer, MapLayer mapLayer,
87 alfonx 111 JMapPane mapPane, MapPaneToolBar toolBar) {
88 alfonx 97
89     super(layerSelModel);
90     this.styledMapLayer = styledMapLayer;
91    
92     this.mapLayer = mapLayer;
93     this.mapPane = mapPane;
94 alfonx 111 this.toolBar = toolBar;
95 alfonx 97 }
96    
97     /**
98     * Called by {@link StyledLayerSelectionModel} when a the selection on other
99     * selection components (map, chart, ...) has changed. When calling this
100     *
101     * method changes the {@link MapLayer} selection according to the
102     * {@link StyledLayerSelectionModel} selection.
103     *
104     * @param evt
105     * an event
106     */
107     @Override
108     public void propertyChange(PropertyChangeEvent evt) {
109     if (!(evt instanceof StyledLayerSelectionEvent))
110     return;
111     StyledLayerSelectionEvent selEvt = (StyledLayerSelectionEvent) evt;
112     // Only react on own layer and ignore events invoked by
113     // this component itself
114     if (selEvt.getEmitter() != layerSelModel || selectionChangeCausedByMe)
115     return;
116     // Apply new selection on table (except this event is one of
117     // some more events)
118 alfonx 111 Vector<String> newSelection = layerSelModel.getSelection();
119 alfonx 97 if (newSelection == null)
120     return;
121    
122     // Avoid event circles in valueChanged(..)
123     selectionChangeCausedByMe = true;
124    
125     changeLayerStyle(newSelection);
126    
127     // Danger of event circles in valueChanged(..) banned
128     selectionChangeCausedByMe = false;
129     }
130    
131 alfonx 111 private void changeLayerStyle(final Vector<String> newSelection) {
132 alfonx 97 Style selectionMapStyle = null;
133     try {
134     if (newSelection.isEmpty()) {
135    
136     selectionMapStyle = styledMapLayer.getStyle();
137 alfonx 111 LOGGER.debug("NO SELECTION .. set to original style directly");
138 alfonx 106
139 alfonx 97 } else {
140 alfonx 100 LOGGER.debug("SELECTION .. change style");
141 alfonx 106
142 alfonx 123 // We take Style from the MapLayer that is displayed at the
143     // moment. We do not use the styledMapLayer.getStyle, because in
144     // the atlas, this always return the default style, but
145     // additionaly styles might be selected.
146     // Taking the style from the mapLayer indicated, that we have to
147 alfonx 125 // remove any selection rules first.
148 alfonx 123 Style originalStyle = mapLayer.getStyle();
149 alfonx 101
150 alfonx 123 // TODO The default style is not good here. We need
151     // .createSelectionStyle(normalStyle, geoObj);
152 alfonx 107 selectionMapStyle = StylingUtil
153 alfonx 106 .createDefaultStyle(styledMapLayer.getGeoObject());
154    
155 alfonx 123 selectionMapStyle.getFeatureTypeStyles()[0]
156     .setName(SELECTION_STYLING);
157    
158 alfonx 111 // Symbolizer sss =
159     // selectionMapStyle.getFeatureTypeStyles()[0].getRules()[0].getSymbolizers()[0];
160     // if (sss instanceof PolygonSymbolizer) {
161     // PolygonSymbolizer ps = (PolygonSymbolizer) sss;
162     // ps.getFill().setOpacity( FilterUtil.FILTER_FAC.literal(0.5));
163     // }
164    
165 alfonx 106 // Rule selectedRule = StylingUtil.STYLE_FACTORY.createRule();
166 alfonx 107 selectionMapStyle.getFeatureTypeStyles()[0].getRules()[0]
167 alfonx 106 .setFilter(new Filter() {
168    
169     @Override
170     public Object accept(FilterVisitor visitor,
171     Object extraData) {
172     return null;
173 alfonx 105 }
174 alfonx 106
175     @Override
176     public boolean evaluate(Object obj) {
177     if (obj instanceof Feature) {
178     Feature f = (Feature) obj;
179 alfonx 125 // TODO BAD CODE! says Martin.. i am fine
180     // with it.. well.. not great...
181 alfonx 111 for (String ffID : newSelection) {
182     if (ffID.equals(f.getID()))
183 alfonx 106 return true;
184     }
185     return false;
186    
187     }
188     return false;
189     }
190    
191     });
192    
193 alfonx 125 FeatureTypeStyle[] originalFeatureTypeStyles = originalStyle
194     .getFeatureTypeStyles();
195     FeatureTypeStyle[] newFeatureTypes;
196     if (originalFeatureTypeStyles[originalFeatureTypeStyles.length - 1]
197     .getName() != null
198     && originalFeatureTypeStyles[originalFeatureTypeStyles.length - 1]
199     .getName().equals(SELECTION_STYLING)) {
200     newFeatureTypes = Arrays.copyOf(originalFeatureTypeStyles,
201     originalFeatureTypeStyles.length - 1);
202 alfonx 123 } else {
203     newFeatureTypes = originalFeatureTypeStyles;
204     }
205 alfonx 125 //
206     // // REMOVE any Selection_Styling FTS (usually the last one)
207     //
208     // for (FeatureTypeStyle fts : originalFeatureTypeStyles){
209     // if (fts.getName().equals(SELECTION_STYLING)) continue;
210     // newFeatureTypes =
211     //
212     // LangUtil.extendArray(
213     // originalFeatureTypeStyles, selectionMapStyle
214     // .getFeatureTypeStyles());
215     // }
216    
217 alfonx 123 // The last FTS is the selection FTS
218 alfonx 125 newFeatureTypes = LangUtil.extendArray(newFeatureTypes,
219     selectionMapStyle.getFeatureTypeStyles());
220    
221 alfonx 123 selectionMapStyle.setFeatureTypeStyles(newFeatureTypes);
222 alfonx 106
223     // selectionMapStyle.setFeatureTypeStyles(originalStyle.getF)
224    
225 alfonx 101 // Flat copy the style
226 alfonx 106
227     // selectionMapStyle =
228     // StylingUtil.createDefaultStyle(styledMapLayer.getGeoObject());
229    
230 alfonx 97 }
231    
232     mapLayer.setStyle(selectionMapStyle);
233     mapPane.refresh();
234     } catch (Exception e) {
235     LOGGER.error("Error while trying to create a selection style", e);
236     }
237     }
238    
239     @Override
240     public void performMapPaneEvent(JMapPaneEvent e) {
241 alfonx 106
242 alfonx 111 /**
243     * Only listen to FeatureSelectionEvents if the appropriate tool is
244     * selected.
245     */
246     final int selectedTool = toolBar.getSelectedTool();
247     if (selectedTool != MapPaneToolBar.TOOL_SELECTION_ADD
248     && selectedTool != MapPaneToolBar.TOOL_SELECTION_REMOVE
249     && selectedTool != MapPaneToolBar.TOOL_SELECTION_CLEAR
250     && selectedTool != MapPaneToolBar.TOOL_SELECTION_SET) {
251     return;
252     }
253    
254 alfonx 105 if (!(e instanceof FeatureSelectedEvent)) {
255 alfonx 111 // LOGGER.debug("Ignoring event " + e);
256 alfonx 97 return;
257 alfonx 105 }
258 mojays 109 // only listen to events directly coming from JMapPane
259     // selection (ignore selections from FilterDialog)
260 alfonx 111 if (e.getSourceObject() != this.mapPane)
261     return;
262    
263 alfonx 97 FeatureSelectedEvent fse = (FeatureSelectedEvent) e;
264    
265     // ignore event if it is caused by the DpLayerVectorSelectionModel
266     if (selectionChangeCausedByMe)
267     return;
268    
269 alfonx 111 LOGGER.debug("Do event " + fse);
270    
271 alfonx 97 // Avoid event circles in propertyChange(..)
272     selectionChangeCausedByMe = true;
273    
274 alfonx 111 if (selectedTool == MapPaneToolBar.TOOL_SELECTION_CLEAR) {
275     layerSelModel.clearSelection();
276     } else {
277     Collection<Feature> selectionResult = (Collection<Feature>) fse
278     .getSelectionResult();
279 alfonx 97
280 alfonx 111 // reset the selection of the DpLayerSelectionModel
281     // layerSelModel.setValueIsAdjusting(true);
282 alfonx 97
283 alfonx 111 if (selectedTool == MapPaneToolBar.TOOL_SELECTION_ADD) {
284     layerSelModel.setValueIsAdjusting(true);
285     for (Feature f : selectionResult) {
286     layerSelModel.addSelection(f.getID());
287     }
288     layerSelModel.setValueIsAdjusting(false);
289     } else if (selectedTool == MapPaneToolBar.TOOL_SELECTION_SET) {
290     layerSelModel.setValueIsAdjusting(true);
291     layerSelModel.clearSelection();
292 alfonx 97
293 alfonx 111 for (Feature f : selectionResult) {
294     layerSelModel.addSelection(f.getID());
295     }
296    
297     LOGGER.debug("Setting selection to " + selectionResult.size());
298     layerSelModel.setValueIsAdjusting(false);
299     } else if (selectedTool == MapPaneToolBar.TOOL_SELECTION_REMOVE) {
300     layerSelModel.setValueIsAdjusting(true);
301     for (Feature f : selectionResult) {
302     layerSelModel.removeSelection(f.getID());
303     }
304     layerSelModel.setValueIsAdjusting(false);
305     }
306     } // els it's not a Clear Selection command
307    
308     // Show selected features in the map, which is not automatically done by
309     // the origin: FeatureSelectedEvent
310 alfonx 97 changeLayerStyle(layerSelModel.getSelection());
311 alfonx 106
312 alfonx 97 // Danger of event circles in propertyChange(..) banned
313     selectionChangeCausedByMe = false;
314     }
315     }

Properties

Name Value
svn:eol-style native
svn:keywords Id
svn:mime-type text/plain

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26