/[schmitzm]/branches/2.1/src/skrueger/geotools/selection/ChartSelectionSynchronizer.java
ViewVC logotype

Diff of /branches/2.1/src/skrueger/geotools/selection/ChartSelectionSynchronizer.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/src/skrueger/geotools/selection/ChartSelectionSynchronizer.java revision 134 by mojays, Sat May 30 20:22:00 2009 UTC branches/2.0-RC1/src/skrueger/geotools/selection/ChartSelectionSynchronizer.java revision 604 by alfonx, Wed Dec 9 14:15:53 2009 UTC
# Line 1  Line 1 
1  /** SCHMITZM - This file is part of the java library of Martin O.J. Schmitz (SCHMITZM)  /*******************************************************************************
2     * Copyright (c) 2009 Martin O. J. Schmitz.
3      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.   *
4      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.   * This file is part of the SCHMITZM library - a collection of utility
5      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   * classes based on Java 1.6, focusing (not only) on Java Swing
6     * and the Geotools library.
7      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.   *
8      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.   * The SCHMITZM project is hosted at:
9      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.   * http://wald.intevation.org/projects/schmitzm/
10   **/   *
11     * This program is free software; you can redistribute it and/or
12  package skrueger.geotools.selection;   * modify it under the terms of the GNU Lesser General Public License
13     * as published by the Free Software Foundation; either version 3
14  import java.beans.PropertyChangeEvent;   * of the License, or (at your option) any later version.
15  import java.beans.PropertyChangeListener;   *
16  import java.util.Vector;   * This program is distributed in the hope that it will be useful,
17     * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  import javax.swing.JTable;   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  import javax.swing.ListSelectionModel;   * GNU General Public License for more details.
20  import javax.swing.event.ListSelectionListener;   *
21  import javax.swing.plaf.basic.BasicTreeUI.SelectionModelPropertyChangeHandler;   * You should have received a copy of the GNU Lesser General Public License (license.txt)
22     * along with this program; if not, write to the Free Software
23  import org.jfree.chart.JFreeChart;   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
24  import org.jfree.data.general.Dataset;   * or try this link: http://www.gnu.org/licenses/lgpl.html
25  import org.jfree.data.general.SeriesDataset;   *
26  import org.jfree.data.xy.XYSeriesCollection;   * Contributors:
27     *     Martin O. J. Schmitz - initial API and implementation
28  import schmitzm.geotools.gui.FeatureCollectionTableModel;   *     Stefan A. Krüger - additional utility classes
29  import schmitzm.jfree.chart.renderer.SelectionRenderer;   ******************************************************************************/
30  import schmitzm.jfree.chart.selection.DatasetSelectionListener;  package skrueger.geotools.selection;
31  import schmitzm.jfree.chart.selection.DatasetSelectionModel;  
32  import schmitzm.jfree.chart.selection.DatasetSelectionModelProvider;  import java.beans.PropertyChangeEvent;
33  import schmitzm.jfree.chart.selection.DatasetSelectionChangeEvent;  import java.beans.PropertyChangeListener;
34  import schmitzm.jfree.feature.Feature2DatasetItemDatasetGroup;  import java.util.Vector;
35    
36  /**  import org.jfree.data.general.Dataset;
37   * This class keeps the selection of a {@link Dataset} (based on feature  
38   * attributes) synchronized with the {@link StyledLayerSelectionModel} of a layer.  import schmitzm.jfree.chart.renderer.SelectionRenderer;
39   * This is done by implementing:  import schmitzm.jfree.chart.selection.DatasetSelectionChangeEvent;
40   * <ul>  import schmitzm.jfree.chart.selection.DatasetSelectionListener;
41   * <li>a {@link PropertyChangeListener} which listens to the  import schmitzm.jfree.chart.selection.DatasetSelectionModel;
42   * {@link StyledLayerSelectionModel} and accordingly changes the {@link SelectionRenderer}  import schmitzm.jfree.chart.selection.DatasetSelectionModelProvider;
43   * selection</li>  import schmitzm.jfree.feature.FeatureDatasetSelectionModel;
44   * <li>a {@link DatasetSelectionModel} which listens to the {@link SelectionRenderer} and  
45   * accordingly changes the {@link StyledLayerSelectionModel} selection</li>  /**
46   * </ul>   * This class keeps the selection of a {@link Dataset} (based on feature
47   * After creating, the instance of this synchronizer must be added as listener   * attributes) synchronized with the {@link StyledLayerSelectionModel} of a layer.
48   * to both, the {@link StyledLayerSelectionModel} and the chart's   * This is done by implementing:
49   * {@link DatasetSelectionModel} (e.g. the renderer).   * <ul>
50   * @see DatasetSelectionModelProvider   * <li>a {@link PropertyChangeListener} which listens to the
51   * @author <a href="mailto:[email protected]">Martin Schmitz</a>   * {@link StyledLayerSelectionModel} and accordingly changes the {@link SelectionRenderer}
52   */   * selection</li>
53  public class ChartSelectionSynchronizer extends StyledLayerSelectionModelSynchronizer<StyledFeatureLayerSelectionModel>   * <li>a {@link DatasetSelectionModel} which listens to the {@link SelectionRenderer} and
54                                          implements DatasetSelectionListener {   * accordingly changes the {@link StyledLayerSelectionModel} selection</li>
55     * </ul>
56    /** Holds the chart datset to keep synchronized with the layer selection model. */   * After creating, the instance of this synchronizer must be added as listener
57    protected DatasetSelectionModel<?> datasetSelModel = null;   * to both, the {@link StyledLayerSelectionModel} and the chart's
58    /** Hold the mapping between feature IDs and dataset items. */   * {@link DatasetSelectionModel} (e.g. the renderer).
59    protected Feature2DatasetItemDatasetGroup<?> mapping = null;   * @see DatasetSelectionModelProvider
60       * @author <a href="mailto:[email protected]">Martin Schmitz</a>
61    /**   */
62     * Creates a new synchronizer.  public class ChartSelectionSynchronizer extends StyledLayerSelectionModelSynchronizer<StyledFeatureLayerSelectionModel>
63     * @param layerSelModel                                          implements DatasetSelectionListener {
64     *             layer selection model to keep synchronized with the dataset  
65     *             selection model    /** Holds the chart datset to keep synchronized with the layer selection model. */
66     * @param datasetSelModel    protected FeatureDatasetSelectionModel<?,?,?> datasetSelModel = null;
67     *            dataset selection model to keep synchronized with the layer  
68     *            selection model    /**
69     */     * Creates a new synchronizer.
70    public ChartSelectionSynchronizer(StyledFeatureLayerSelectionModel layerSelModel, DatasetSelectionModel<?> datasetSelModel) {     * @param layerSelModel
71      super(layerSelModel);     *             layer selection model to keep synchronized with the dataset
72      // the dataset selection model must provide a mapping     *             selection model
73      // to the feature IDs     * @param datasetSelModel
74      if ( datasetSelModel.getDataset() == null ||     *            dataset selection model to keep synchronized with the layer
75           !(datasetSelModel.getDataset().getGroup() instanceof Feature2DatasetItemDatasetGroup) )     *            selection model
76        throw new UnsupportedOperationException("Dataset must provide a Feature2DatasetItemDatasetGroup as DatasetGroup.");     */
77      this.datasetSelModel = datasetSelModel;    public ChartSelectionSynchronizer(StyledFeatureLayerSelectionModel layerSelModel, FeatureDatasetSelectionModel<?,?,?> datasetSelModel) {
78      this.mapping         = (Feature2DatasetItemDatasetGroup<?>)datasetSelModel.getDataset().getGroup();      super(layerSelModel);
79    }      this.datasetSelModel = datasetSelModel;
80      }
81    /**  
82     * Called by {@link StyledLayerSelectionModel} when a the selection on other    /**
83     * selection components (map, table, ...) has changed. When calling this     * Called by {@link StyledLayerSelectionModel} when the selection on other
84     * method changes the dataset selection according to the     * selection components (map, table, ...) has changed. When calling this
85     * {@link StyledLayerSelectionModel} selection.     * method changes the dataset selection according to the
86     * @param evt an event     * {@link StyledLayerSelectionModel} selection.
87     */     * @param evt an event
88    @Override     */
89    public void propertyChange(PropertyChangeEvent evt) {    @Override
90      if (!(evt instanceof StyledLayerSelectionEvent))    public void propertyChange(PropertyChangeEvent evt) {
91        return;          
92      StyledLayerSelectionEvent selEvt = (StyledLayerSelectionEvent) evt;          if (!isEnabled())
93      // Only react on own layer and ignore events invoked by                  return;
94      // this component itself            
95      if (selEvt.getEmitter() != layerSelModel || selectionChangeCausedByMe)      if (!(evt instanceof StyledLayerSelectionEvent))
96          return;        return;
97      // Apply new selection on chart (except this event is one of      StyledLayerSelectionEvent selEvt = (StyledLayerSelectionEvent) evt;
98      // some more events)      // Only react on own layer and ignore events invoked by
99      Vector<String> newSelection = layerSelModel.getSelection();      // this component itself
100      if (newSelection == null)      if (selEvt.getEmitter() != layerSelModel || selectionChangeCausedByMe)
101        return;          return;
102        // Apply new selection on chart (except this event is one of
103      // Avoid event circles in valueChanged(..)      // some more events)
104      selectionChangeCausedByMe = true;      Vector<String> newSelection = layerSelModel.getSelection();
105        if (newSelection == null)
106      datasetSelModel.setValueIsAdjusting(true);        return;
107      datasetSelModel.clearSelection();  
108            // Avoid event circles in valueChanged(..)
109      for (String fID : newSelection) {      selectionChangeCausedByMe = true;
110        Comparable dataID = mapping.getDataID(fID);  
111        if (dataID != null ) {      datasetSelModel.setValueIsAdjusting(true);
112  //TODO: Fallunterscheidung zwischen den unterschiedlichen DatasetSelectionModel-Typen!!      datasetSelModel.clearSelection();
113        } else {      for (String fID : newSelection)
114            LOGGER.warn("Something that is not visible in the chart should be selected");        datasetSelModel.setItemSelected(fID, true);
115        }      datasetSelModel.setValueIsAdjusting(false); // event is fired autmatically!
116      }  
117      datasetSelModel.setValueIsAdjusting(false); // event is fired autmatically!      // Danger of event circles in valueChanged(..) banned
118        selectionChangeCausedByMe = false;
119      // Danger of event circles in valueChanged(..) banned    }
120      selectionChangeCausedByMe = false;  
121    }    /**
122       * Called when the chart selection is changed by the user. When calling this
123    @Override     * method changes the selection of the {@link StyledLayerSelectionModel}.
124    public void selectionChanged(DatasetSelectionChangeEvent e) {     * @param evt an event
125      // TODO Auto-generated method stub     */
126          @Override
127    }    public void selectionChanged(DatasetSelectionChangeEvent evt) {
128          // ignore event if it is part of multiple events
129        if (evt != null && evt.getSource().getValueIsAdjusting())
130  }          return;
131        // ignore event if it is caused by the ChartSelectionSynchronizer
132        if (selectionChangeCausedByMe)
133            return;
134    
135        // Avoid event circles in propertyChange(..)
136        selectionChangeCausedByMe = true;
137    
138        // reset the selection of the DpLayerSelectionModel
139        layerSelModel.setValueIsAdjusting(true);
140        layerSelModel.clearSelection();
141        for (String featureID : datasetSelModel.getSelectedFeatures())
142          layerSelModel.addSelection(featureID);
143        layerSelModel.setValueIsAdjusting(false);
144    
145        // Danger of event circles in propertyChange(..) banned
146        selectionChangeCausedByMe = false;
147      }
148      
149    
150    }

Legend:
Removed from v.134  
changed lines
  Added in v.604

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26