Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/process/SedimentDensityProcessor.java @ 7505:4efa34256b62
issue1658: Fix SedimentLoadLSGenerator (with surprise: isnt that done via processors?).
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Fri, 01 Nov 2013 16:37:19 +0100 |
parents | 7a7ce43ddd3f |
children | e4606eae8ea5 |
rev | line source |
---|---|
7214
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
1 /* Copyright (C) 2013 by Bundesanstalt für Gewässerkunde |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
2 * Software engineering by Intevation GmbH |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
3 * |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
4 * This file is Free Software under the GNU AGPL (>=v3) |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
6 * documentation coming with Dive4Elements River for details. |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
7 */ |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
8 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
9 package org.dive4elements.river.exports.process; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
10 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
11 import org.apache.log4j.Logger; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
12 import org.jfree.data.xy.XYSeries; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
13 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
15 import org.dive4elements.artifacts.CallContext; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
16 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
17 import org.dive4elements.river.artifacts.model.FacetTypes; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
18 import org.dive4elements.river.artifacts.model.minfo.SedimentDensity; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
19 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
20 import org.dive4elements.river.exports.DiagramGenerator; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
21 import org.dive4elements.river.exports.StyledSeriesBuilder; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
22 import org.dive4elements.river.jfree.StyledXYSeries; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
23 import org.dive4elements.river.themes.ThemeDocument; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
24 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
25 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
26 /** Process Sediment Density data. */ |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
27 public class SedimentDensityProcessor extends DefaultProcessor { |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
28 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
29 /** Private logger. */ |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
30 private final static Logger logger = |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
31 Logger.getLogger(SedimentDensityProcessor.class); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
32 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
33 public static final String I18N_AXIS_LABEL_DEFAULT = |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
34 "Sedimentdichte [t/m^3]"; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
35 public static final String I18N_AXIS_LABEL = |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
36 "chart.yaxis.label.sedimentdensity"; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
37 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
38 @Override |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
39 public void doOut( |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
40 DiagramGenerator generator, |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
41 ArtifactAndFacet bundle, |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
42 ThemeDocument theme, |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
43 boolean visible) { |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
44 CallContext context = generator.getCallContext(); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
45 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(), |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
46 theme); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
47 Object data = bundle.getData(context); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
48 String facetName = bundle.getFacetName(); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
49 double [][] points; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
50 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
51 if (facetName.equals(FacetTypes.SEDIMENT_DENSITY)) { |
7310
7a7ce43ddd3f
SedimentDensityProcessor: Fix, use getAllDensities instead of only dens. in year 2006.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7214
diff
changeset
|
52 points =((SedimentDensity) data).getAllDensities(); |
7214
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
53 } else { |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
54 logger.error("Unknown facet name: " + facetName); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
55 return; |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
56 } |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
57 StyledSeriesBuilder.addPoints(series, points, true); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
58 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
59 generator.addAxisSeries(series, axisName, visible); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
60 } |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
61 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
62 @Override |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
63 public boolean canHandle(String facettype) { |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
64 return facettype.equals(FacetTypes.SEDIMENT_DENSITY); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
65 } |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
66 |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
67 @Override |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
68 public String getAxisLabel(DiagramGenerator generator) { |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
69 return generator.msg( |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
70 I18N_AXIS_LABEL, |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
71 I18N_AXIS_LABEL_DEFAULT); |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
72 } |
8817bb81cf27
Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff
changeset
|
73 } |