annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedheightProcessor.java @ 7127:1106f580420c

Add axis label to bedheight processor.
author Andre Heinecke <aheinecke@intevation.de>
date Wed, 25 Sep 2013 11:47:45 +0200
parents cdae0ff8960b
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;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
18 import org.dive4elements.river.artifacts.model.minfo.BedHeightSingle;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
19 import org.dive4elements.river.exports.XYChartGenerator;
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
20 import org.dive4elements.river.exports.DiagramGenerator;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
21 import org.dive4elements.river.jfree.StyledXYSeries;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4551
diff changeset
22 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
23 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
24
7057
1011a40ee79c Add Default Processor implementation and make processors inherit it.
Andre Heinecke <aheinecke@intevation.de>
parents: 6905
diff changeset
25 public class BedheightProcessor extends DefaultProcessor {
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
26
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
27 private final static Logger logger =
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
28 Logger.getLogger(BedheightProcessor.class);
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
29
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
30 private final static String BEDHEIGHT = "bedheight";
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
31
7127
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
32 public static final String I18N_AXIS_LABEL_DEFAULT
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
33 = "Gepeilte Breite [m]";
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
34 public static final String I18N_AXIS_LABEL =
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
35 "chart.bedheight_middle.sounding.yaxis.label";
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
36
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
37 @Override
4551
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
38 public void doOut(
7093
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
39 DiagramGenerator generator,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
40 ArtifactAndFacet bundle,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
41 ThemeDocument theme,
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
42 boolean visible) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
43 CallContext context = generator.getCallContext();
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
44 Object data = bundle.getData(context);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
45 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
46 theme);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
47 if (data instanceof BedHeightSingle) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
48 BedHeightSingle bData = (BedHeightSingle)data;
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
49 double[] width = bData.getMorphWidths();
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
50 double[] stations = bData.getStations().toNativeArray();
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
51
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
52 logger.debug("doBedheightSingleOut");
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
53
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
54 for (int i = 0; i < width.length; i++) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
55 series.add(stations[i], width[i], false);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
56 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
57 } else if (data instanceof List<?>) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
58 List<BedHeightSingleValue> bData = (List<BedHeightSingleValue>)data;
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
59
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
60 logger.debug("doBedheightSingleValueOut");
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
61
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
62 for(BedHeightSingleValue bvalue: bData) {
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
63 series.add(bvalue.getStation(), bvalue.getSoundingWidth());
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
64 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
65 }
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
66 generator.addAxisSeries(series, axisName, visible);
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
67 }
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 @Override
cdae0ff8960b Add DiagramGenerator doOut function
Andre Heinecke <aheinecke@intevation.de>
parents: 7091
diff changeset
70 public void doOut(
4551
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
71 XYChartGenerator generator,
7075
253d80af5b7f More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents: 7057
diff changeset
72 ArtifactAndFacet bundle,
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
73 ThemeDocument theme,
4551
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
74 boolean visible,
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
75 int index
2fadc6c5cdad Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4536
diff changeset
76 ) {
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
77 CallContext context = generator.getCallContext();
7075
253d80af5b7f More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents: 7057
diff changeset
78 Object data = bundle.getData(context);
253d80af5b7f More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents: 7057
diff changeset
79 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
80 theme);
7091
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
81 if (data instanceof BedHeightSingle) {
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
82 BedHeightSingle bData = (BedHeightSingle)data;
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
83 double[] width = bData.getMorphWidths();
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
84 double[] stations = bData.getStations().toNativeArray();
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
85
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
86 logger.debug("doBedheightSingleOut");
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
87
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
88 for (int i = 0; i < width.length; i++) {
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
89 series.add(stations[i], width[i], false);
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
90 }
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
91 } else if (data instanceof List<?>) {
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
92 List<BedHeightSingleValue> bData = (List<BedHeightSingleValue>)data;
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
93
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
94 logger.debug("doBedheightSingleValueOut");
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
95
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
96 for(BedHeightSingleValue bvalue: bData) {
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
97 series.add(bvalue.getStation(), bvalue.getSoundingWidth());
c7d8adb91576 Simplify code to prepare DiagramGenerator signature
Andre Heinecke <aheinecke@intevation.de>
parents: 7075
diff changeset
98 }
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
99 }
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
100 generator.addAxisSeries(series, index, visible);
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
101 }
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
102
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
103 @Override
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
104 public boolean canHandle(String facettype) {
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
105 return BEDHEIGHT.equals(facettype);
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
106 }
7127
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
107
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
108 @Override
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
109 public String getAxisLabel(DiagramGenerator generator) {
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
110 return generator.msg(
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
111 I18N_AXIS_LABEL,
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
112 I18N_AXIS_LABEL_DEFAULT);
1106f580420c Add axis label to bedheight processor.
Andre Heinecke <aheinecke@intevation.de>
parents: 7093
diff changeset
113 }
4536
ce4ff444f215 Implement a BedheightProcessor to generate charts from bed height data
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
114 }

http://dive4elements.wald.intevation.org