annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedHeightSoundingProcessor.java @ 7477:bc16d5031b31

issue1657: Spawn BEDHEIGHT_SOUNDING_WIDTH facet if asked to. Twiggly.
author Felix Wolfsteller <felix.wolfsteller@intevation.de>
date Thu, 31 Oct 2013 11:43:32 +0100
parents 5eafd73312ae
children
rev   line source
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
2 * Software engineering by Intevation GmbH
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
3 *
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
6 * documentation coming with Dive4Elements River for details.
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
7 */
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
8
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
9 package org.dive4elements.river.exports.process;
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
10
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
11 import java.util.List;
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
12
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
14 import org.jfree.data.xy.XYSeries;
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
15
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
16 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
17 import org.dive4elements.artifacts.CallContext;
7391
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7389
diff changeset
18 import org.dive4elements.river.artifacts.model.minfo.BedHeightSingleData;
7394
5eafd73312ae BedHeight(Sounding)Processor: Use FacetTypes.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7391
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
20 import org.dive4elements.river.exports.XYChartGenerator;
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
21 import org.dive4elements.river.exports.DiagramGenerator;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
22 import org.dive4elements.river.jfree.StyledXYSeries;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
23 import org.dive4elements.river.model.BedHeightSingleValue;
6905
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5994
diff changeset
24 import org.dive4elements.river.themes.ThemeDocument;
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
25
7144
b6595716f5f0 Rename BedWidthProcessor to BedHeightSounding processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7128
diff changeset
26 public class BedHeightSoundingProcessor extends DefaultProcessor {
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
27
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
28 private final static Logger logger =
7144
b6595716f5f0 Rename BedWidthProcessor to BedHeightSounding processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7128
diff changeset
29 Logger.getLogger(BedHeightSoundingProcessor.class);
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
30
7127
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
31 public static final String I18N_AXIS_LABEL_DEFAULT
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
32 = "Gepeilte Breite [m]";
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
33 public static final String I18N_AXIS_LABEL =
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
34 "chart.bedheight_middle.sounding.yaxis.label";
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
35
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
36 @Override
4551
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
37 public void doOut(
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
38 DiagramGenerator generator,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
39 ArtifactAndFacet bundle,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
40 ThemeDocument theme,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
41 boolean visible) {
7388
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
42 XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
43 generator.addAxisSeries(series, axisName, visible);
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
44 }
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
45
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
46 @Override
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
47 public void doOut(
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
48 XYChartGenerator generator,
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
49 ArtifactAndFacet bundle,
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
50 ThemeDocument theme,
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
51 boolean visible,
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
52 int index
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
53 ) {
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
54 XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
55 generator.addAxisSeries(series, index, visible);
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
56 }
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
57
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
58 /** Prepare an series, independent of axis. */
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
59 private XYSeries prepareSeries(ArtifactAndFacet bundle,
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
60 ThemeDocument theme, CallContext context) {
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
61 Object data = bundle.getData(context);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
62 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
63 theme);
7391
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7389
diff changeset
64 if (data instanceof BedHeightSingleData) {
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7389
diff changeset
65 BedHeightSingleData bData = (BedHeightSingleData)data;
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
66 double[] width = bData.getMorphWidths();
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
67 double[] stations = bData.getStations().toNativeArray();
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
68
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
69 logger.debug("doBedheightSingleOut");
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
70
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
71 for (int i = 0; i < width.length; i++) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
72 series.add(stations[i], width[i], false);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
73 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
74 } else if (data instanceof List<?>) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
75 List<BedHeightSingleValue> bData = (List<BedHeightSingleValue>)data;
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
76
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
77 logger.debug("doBedheightSingleValueOut");
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
78
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
79 for(BedHeightSingleValue bvalue: bData) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
80 series.add(bvalue.getStation(), bvalue.getSoundingWidth());
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
81 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
82 }
7389
2c3031b6a831 BedHeightSoundingProcessor: Log if data is now handled.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7388
diff changeset
83 else {
2c3031b6a831 BedHeightSoundingProcessor: Log if data is now handled.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7388
diff changeset
84 logger.error("Unknown data type " + data.getClass());
2c3031b6a831 BedHeightSoundingProcessor: Log if data is now handled.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7388
diff changeset
85 }
7388
c4a03db67198 BedHeightSoundingProcessor: refactored to avoid drifting behavior when using
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7144
diff changeset
86 return series;
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
87 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
88
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
89
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
90 @Override
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
91 public boolean canHandle(String facettype) {
7477
bc16d5031b31 issue1657: Spawn BEDHEIGHT_SOUNDING_WIDTH facet if asked to. Twiggly.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7394
diff changeset
92 return FacetTypes.BEDHEIGHT_SOUNDING_WIDTH.equals(facettype);
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
93 }
7127
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
94
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
95 @Override
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
96 public String getAxisLabel(DiagramGenerator generator) {
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
97 return generator.msg(
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
98 I18N_AXIS_LABEL,
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
99 I18N_AXIS_LABEL_DEFAULT);
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
100 }
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
101 }

http://dive4elements.wald.intevation.org