/[schmitzm]/branches/2.0-RC2/src/skrueger/geotools/StyledFS.java
ViewVC logotype

Diff of /branches/2.0-RC2/src/skrueger/geotools/StyledFS.java

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

trunk/src/skrueger/geotools/StyledFS.java revision 222 by alfonx, Tue Jul 14 14:46:39 2009 UTC branches/1.0-gt2-2.6/src/skrueger/geotools/StyledFS.java revision 336 by alfonx, Thu Aug 27 09:10:10 2009 UTC
# Line 1  Line 1 
1  package skrueger.geotools;  /*******************************************************************************
2     * Copyright (c) 2009 Martin O. J. Schmitz.
3  import java.io.File;   *
4  import java.io.FileNotFoundException;   * This file is part of the SCHMITZM library - a collection of utility
5  import java.io.IOException;   * classes based on Java 1.6, focusing (not only) on Java Swing
6  import java.net.URL;   * and the Geotools library.
7  import java.util.Date;   *
8  import java.util.HashMap;   * The SCHMITZM project is hosted at:
9  import java.util.Map;   * http://wald.intevation.org/projects/schmitzm/
10  import java.util.Random;   *
11     * This program is free software; you can redistribute it and/or
12  import javax.swing.ImageIcon;   * modify it under the terms of the GNU Lesser General Public License
13  import javax.swing.JPanel;   * as published by the Free Software Foundation; either version 3
14     * of the License, or (at your option) any later version.
15  import org.apache.log4j.Logger;   *
16  import org.geotools.data.FeatureSource;   * This program is distributed in the hope that it will be useful,
17  import org.geotools.feature.AttributeType;   * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  import org.geotools.feature.FeatureCollection;   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  import org.geotools.styling.Style;   * GNU General Public License for more details.
20  import org.opengis.referencing.crs.CoordinateReferenceSystem;   *
21     * You should have received a copy of the GNU Lesser General Public License (license.txt)
22  import schmitzm.geotools.feature.FeatureOperationTreeFilter;   * along with this program; if not, write to the Free Software
23  import schmitzm.geotools.styling.StylingUtil;   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
24  import skrueger.AttributeMetaData;   * or try this link: http://www.gnu.org/licenses/lgpl.html
25  import skrueger.i8n.Translation;   *
26     * Contributors:
27  import com.vividsolutions.jts.geom.Envelope;   *     Martin O. J. Schmitz - initial API and implementation
28     *     Stefan A. Krüger - additional utility classes
29  /**   ******************************************************************************/
30   * This class enables a non Atlas context to use the Atlas LayerPanel  package skrueger.geotools;
31   * {@link JPanel} as a {@link MapContextManagerInterface}  
32   *  import java.io.File;
33   * @author <a href="mailto:[email protected]">Stefan Alfons Kr&uuml;ger</a>  import java.io.FileNotFoundException;
34   */  import java.io.IOException;
35  public class StyledFS implements StyledFeatureSourceInterface {  import java.net.URL;
36          private static final Logger LOGGER = Logger.getLogger(StyledFS.class);  import java.util.Date;
37    import java.util.HashMap;
38          private final FeatureSource fs;  import java.util.Map;
39    import java.util.Random;
40          /**  
41           * A unique ID which identifies the Layer in the Atlas. It's more important  import javax.swing.ImageIcon;
42           * than it should be ;-)  import javax.swing.JPanel;
43           */  
44          private String id;  import org.apache.log4j.Logger;
45    import org.geotools.data.FeatureSource;
46          private Style style;  import org.geotools.feature.FeatureCollection;
47    import org.geotools.styling.Style;
48          private Translation title;  import org.opengis.feature.simple.SimpleFeature;
49    import org.opengis.feature.simple.SimpleFeatureType;
50          private Translation desc;  import org.opengis.feature.type.AttributeDescriptor;
51    import org.opengis.referencing.crs.CoordinateReferenceSystem;
52          private File sldFile;  
53    import schmitzm.geotools.styling.StylingUtil;
54          private HashMap<Integer, AttributeMetaData> map;  import skrueger.AttributeMetaData;
55    import skrueger.i8n.Translation;
56          /**  
57           * This class enables a non Atlas context to use the Atlas LayerPanel  import com.vividsolutions.jts.geom.Envelope;
58           * {@link JPanel} as a {@link MapContextManagerInterface}  
59           *  /**
60           * @param fs   * This class enables a non Atlas context to use the Atlas LayerPanel
61           *            {@link FeatureSource} that is beeing styled.   * {@link JPanel} as a {@link MapContextManagerInterface}
62           *   *
63           * @param sldFile   * @author <a href="mailto:[email protected]">Stefan Alfons Kr&uuml;ger</a>
64           *            may be <code>null</code>. Otherwise the SLD {@link File} to   */
65           *            import and associate with this {@link StyledFS}  public class StyledFS implements StyledFeatureSourceInterface {
66           */          private static final Logger LOGGER = Logger.getLogger(StyledFS.class);
67          public StyledFS(FeatureSource fs, File sldFile) {  
68            private final FeatureSource<SimpleFeatureType, SimpleFeature> fs;
69                  this.fs = fs;  
70                  id = StyledFS.class.getSimpleName()          /**
71                                  + new Random(new Date().getTime()).nextInt(10000000);           * A unique ID which identifies the Layer in the Atlas. It's more important
72             * than it should be ;-)
73                  this.sldFile = sldFile;           */
74            private String id;
75                  if ((sldFile != null) && (sldFile.exists())) {  
76                          try {          private Style style;
77                                  style = StylingUtil.loadSLD(sldFile)[0];  
78                          } catch (FileNotFoundException e) {          private Translation title;
79                                  LOGGER  
80                                                  .debug("The SLD file passed was empty. Leaving the Style untouched. (We are in the constructor.. so its null");          private Translation desc;
81                          } catch (Exception e) {  
82                                  LOGGER.warn("Reading SLD failed: " + sldFile, e);          private File sldFile;
83                          }  
84                  }          private HashMap<Integer, AttributeMetaData> map;
85                  title = new Translation();  
86                  title.fromOneLine(sldFile.getName());          /**
87             * This class enables a non Atlas context to use the Atlas LayerPanel
88                  desc = new Translation();           * {@link JPanel} as a {@link MapContextManagerInterface}
89                  desc.fromOneLine(sldFile.getAbsolutePath());           *
90          }           * @param fs
91             *            {@link FeatureSource} that is beeing styled.
92          public void dispose() {           *
93          }           * @param sldFile
94             *            may be <code>null</code>. Otherwise the SLD {@link File} to
95          /**           *            import and associate with this {@link StyledFS}
96           * Returnes human readable {@link String} of the CRS natively used by this           */
97           * {@link DpLayer}          public StyledFS(FeatureSource<SimpleFeatureType, SimpleFeature> fs, File sldFile) {
98           *  
99           * If crs == null, it will call {@link #getGeoObject()}                  this.fs = fs;
100           *                  id = StyledFS.class.getSimpleName()
101           */                                  + new Random(new Date().getTime()).nextInt(10000000);
102          public String getCRSString() {  
103                  if (getCrs() == null)                  this.sldFile = sldFile;
104                          return "CRS?";  
105                    if (sldFile != null && sldFile.exists()) {
106                  return getCrs().getName().getCode();                          try {
107          }                                  style = StylingUtil.loadSLD(sldFile)[0];
108                            } catch (FileNotFoundException e) {
109          public CoordinateReferenceSystem getCrs() {                                  LOGGER
110                  return fs.getSchema().getDefaultGeometry().getCoordinateSystem();                                                  .debug("The SLD file passed was empty. Leaving the Style untouched. (We are in the constructor.. so its null");
111          }                          } catch (Exception e) {
112                                    LOGGER.warn("Reading SLD failed: " + sldFile, e);
113          public Translation getDesc() {                          }
114                  return desc;                  }
115          }                  title = new Translation();
116                    title.fromOneLine(sldFile.getName());
117          public Envelope getEnvelope() {  
118                  try {                  desc = new Translation();
119                          return fs.getBounds();                  desc.fromOneLine(sldFile.getAbsolutePath());
120                  } catch (IOException e) {          }
121                          e.printStackTrace();  
122                          return null;          public void dispose() {
123                  }          }
124          }  
125            /**
126          public FeatureSource getGeoObject() {           * Returns human readable {@link String} of the CRS natively used by this
127                  return fs;           * {@link DpLayer}
128          }           *
129             * If CRS == null, it will call {@link #getGeoObject()}
130          public String getId() {           *
131                  return id;           */
132          }          public String getCRSString() {
133                    if (getCrs() == null)
134          public ImageIcon getImageIcon() {                          return "CRS?";
135                  return null;  
136          }                  return getCrs().getName().getCode();
137            }
138          public URL getInfoURL() {  
139                  return null;          public CoordinateReferenceSystem getCrs() {
140          }                  return fs.getSchema().getCoordinateReferenceSystem();
141            }
142          public Translation getKeywords() {  
143                  return null;          public Translation getDesc() {
144          }                  return desc;
145            }
146          public Style getStyle() {  
147                  return style;          public Envelope getEnvelope() {
148          }                  try {
149                            return fs.getBounds();
150          public Translation getTitle() {                  } catch (IOException e) {
151                  return title;                          e.printStackTrace();
152          }                          return null;
153                    }
154          public boolean isDisposed() {          }
155                  return false;  
156          }          public FeatureSource<SimpleFeatureType, SimpleFeature> getGeoObject() {
157                    return fs;
158          /**          }
159           * If true, this layer will not be shown in the legend. Default = false  
160           */          public String getId() {
161          /**                  return id;
162           *          }
163           * Killed by SK: 6. April 09: Ein Layer soll nicht generell auf  
164           * verstecken/nicht verstecken gestellt werden können. Das sind          public ImageIcon getImageIcon() {
165           * Eigenschaften der Karte/MapContext, ebenso wie die Reihenfolge der Layer.                  return null;
166           * Im Atlas verwaltet deshalb nun die Klasse skrueger.atlas.Map welche Layer          }
167           * nicht in der Legende auftauchen sollen. Meines Wissens hat keiner bisher  
168           * die Funktion genutzt.          public URL getInfoURL() {
169           *                  return null;
170           * // public boolean isHideInLegend() { // return false; // }          }
171           */  
172            public Translation getKeywords() {
173          public void setDesc(Translation dec) {                  return null;
174                  this.desc = dec;          }
175          }  
176            public Style getStyle() {
177          public void setImageIcon(ImageIcon icon) {                  return style;
178          }          }
179    
180          public void setKeywords(Translation keywords) {          public Translation getTitle() {
181          }                  return title;
182            }
183          public void setStyle(Style style) {  
184                  this.style = style;          public boolean isDisposed() {
185                    return false;
186          }          }
187    
188          public void setTitle(Translation title) {          /**
189                  this.title = title;           * If true, this layer will not be shown in the legend. Default = false
190             */
191          }          /**
192             *
193          public void uncache() {           * Killed by SK: 6. April 09: Ein Layer soll nicht generell auf
194          }           * verstecken/nicht verstecken gestellt werden können. Das sind
195             * Eigenschaften der Karte/MapContext, ebenso wie die Reihenfolge der Layer.
196          /**           * Im Atlas verwaltet deshalb nun die Klasse skrueger.atlas.Map welche Layer
197           *           * nicht in der Legende auftauchen sollen. Meines Wissens hat keiner bisher
198           */           * die Funktion genutzt.
199          public Map<Integer, AttributeMetaData> getAttributeMetaDataMap() {           *
200                  if (map == null) {           * // public boolean isHideInLegend() { // return false; // }
201             */
202                          map = new HashMap<Integer, AttributeMetaData>();  
203            public void setDesc(Translation dec) {
204                          // Leaving out the first one, it will be the_geom                  this.desc = dec;
205                          for (int i = 1; i < fs.getSchema().getAttributeCount(); i++) {          }
206                                  AttributeType att = fs.getSchema().getAttributeType(i);  
207            public void setImageIcon(ImageIcon icon) {
208                                  AttributeMetaData attMetaData = new AttributeMetaData(i, att          }
209                                                  .getLocalName());  
210                                  map.put(i, attMetaData);          public void setKeywords(Translation keywords) {
211                          }          }
212                  }  
213                  return map;          public void setStyle(Style style) {
214          }                  this.style = style;
215    
216          /**          }
217           * @return The {@link File} where the SLD was loaded from or  
218           *         <code>null</code> if there didn't exist a {@link File}. (It could          public void setTitle(Translation title) {
219           *         be a WFS or a PostGIS                  this.title = title;
220           *  
221           * @author <a href="mailto:[email protected]">Stefan Alfons          }
222           *         Kr&uuml;ger</a>  
223           */          public void uncache() {
224          public File getSldFile() {          }
225                  return sldFile;  
226          }          /**
227             *
228          public void setSldFile(File sldFile) {           */
229                  this.sldFile = sldFile;          public Map<Integer, AttributeMetaData> getAttributeMetaDataMap() {
230          }                  if (map == null) {
231    
232          /**                          map = new HashMap<Integer, AttributeMetaData>();
233           * Returns the features of the {@link FeatureSource}.  
234           *                          // Leaving out the first one, it will be the_geom
235           * @see {@link StyledFeaturesInterface}                          for (int i = 1; i < fs.getSchema().getAttributeCount(); i++) {
236           */                                  AttributeDescriptor att = fs.getSchema().getDescriptor(i);
237          @Override  
238          public FeatureCollection getFeatureCollection() {                                  AttributeMetaData attMetaData = new AttributeMetaData(i, att
239                  FeatureCollection features;                                                  .getLocalName());
240                  try {                                  map.put(i, attMetaData);
241                          features = getGeoObject().getFeatures();                          }
242                  } catch (IOException e) {                  }
243                          throw new RuntimeException(                  return map;
244                                          "Error getting the features of the  FeatureSource");          }
245                  }  
246                  return features;          /**
247          }           * @return The {@link File} where the SLD was loaded from or
248             *         <code>null</code> if there didn't exist a {@link File}.
249          /**           *
250           * Same as {@link #getGeoObject()} method, but complies to the           * @author <a href="mailto:[email protected]">Stefan Alfons
251           * {@link StyledFeaturesInterface}           *         Kr&uuml;ger</a>
252           *           */
253           * @see {@link StyledFeaturesInterface}          public File getSldFile() {
254           */                  return sldFile;
255          @Override          }
256          public FeatureSource getFeatureSource() {  
257                  return getGeoObject();          public void setSldFile(File sldFile) {
258          }                  this.sldFile = sldFile;
259            }
260  }  
261            /**
262             * Returns the features of the {@link FeatureSource}.
263             *
264             * @see {@link StyledFeaturesInterface}
265             */
266            @Override
267            public FeatureCollection getFeatureCollection() {
268                    FeatureCollection features;
269                    try {
270                            features = getGeoObject().getFeatures();
271                    } catch (IOException e) {
272                            throw new RuntimeException(
273                                            "Error getting the features of the  FeatureSource");
274                    }
275                    return features;
276            }
277    
278            /**
279             * Same as {@link #getGeoObject()} method, but complies to the
280             * {@link StyledFeaturesInterface}
281             *
282             * @see {@link StyledFeaturesInterface}
283             */
284            @Override
285            public FeatureSource getFeatureSource() {
286                    return getGeoObject();
287            }
288    
289    }

Legend:
Removed from v.222  
changed lines
  Added in v.336

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26