annotate artifacts/src/main/java/org/dive4elements/river/exports/MiddleBedHeightGenerator.java @ 6955:94cb1845c667

(issue1452) Coalesce to zero to avoid NaN arithmetic.
author Andre Heinecke <aheinecke@intevation.de>
date Fri, 30 Aug 2013 15:45:14 +0200
parents 0288db5e90d5
children e0311aa32efb
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: 5867
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: 5867
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: 5699
diff changeset
9 package org.dive4elements.river.exports;
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
11 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
12 import org.dive4elements.artifactdatabase.state.Facet;
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
13
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
14 import org.dive4elements.river.artifacts.D4EArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
15 import org.dive4elements.river.artifacts.model.FacetTypes;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
16 import org.dive4elements.river.artifacts.model.MiddleBedHeightData;
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
17 import org.dive4elements.river.artifacts.model.WQKms;
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
18
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
19 import org.dive4elements.river.exports.process.BedheightProcessor;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
20 import org.dive4elements.river.exports.process.Processor;
6927
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
21 import org.dive4elements.river.exports.process.QOutProcessor;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
22 import org.dive4elements.river.exports.process.WOutProcessor;
5864
f2e46a668fe6 River artifacts: Renamed FLYSAnnotation to RiverAnnotation.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
23 import org.dive4elements.river.jfree.RiverAnnotation;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
24 import org.dive4elements.river.jfree.StyledXYSeries;
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: 6430
diff changeset
25 import org.dive4elements.river.themes.ThemeDocument;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5864
diff changeset
26 import org.dive4elements.river.utils.RiverUtils;
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
27
4142
0ac1158605bd Fix typo
Christian Lins <christian.lins@intevation.de>
parents: 4047
diff changeset
28 import org.apache.log4j.Logger;
0ac1158605bd Fix typo
Christian Lins <christian.lins@intevation.de>
parents: 4047
diff changeset
29 import org.jfree.data.xy.XYSeries;
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
30
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5699
diff changeset
31 // TODO Move class to org.dive4elements.river.exports.minfo
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
32 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
33 * An OutGenerator that generates middle bed height charts.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
34 *
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
35 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
36 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
37 public class MiddleBedHeightGenerator
6167
5531d54581db cosmetics: minor indentation fix.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5994
diff changeset
38 extends XYChartGenerator
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
39 implements FacetTypes
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
40 {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
41 public enum YAXIS {
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
42 H(0), W(1), P(2), Q(3);
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
43 protected int idx;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
44 private YAXIS(int c) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
45 idx = c;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
46 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
47 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
48
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
49 /** The logger that is used in this generator. */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
50 private static Logger logger = Logger.getLogger(MiddleBedHeightGenerator.class);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
51
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
52 /** Key to look up internationalized String for annotations label. */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
53 public static final String I18N_ANNOTATIONS_LABEL =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
54 "chart.bedheight_middle.annotations.label";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
55
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
56 public static final String I18N_CHART_TITLE =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
57 "chart.bedheight_middle.section.title";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
58
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
59 public static final String I18N_CHART_SUBTITLE =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
60 "chart.bedheight_middle.section.subtitle";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
61
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
62 public static final String I18N_CHART_SHORT_SUBTITLE =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
63 "chart.bedheight_middle.section.shortsubtitle";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
64
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
65 public static final String I18N_XAXIS_LABEL =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
66 "chart.bedheight_middle.section.xaxis.label";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
67
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
68 public static final String I18N_YAXIS_LABEL =
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
69 "chart.bedheight_middle.section.yaxis.label";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
70
4142
0ac1158605bd Fix typo
Christian Lins <christian.lins@intevation.de>
parents: 4047
diff changeset
71 public static final String I18N_CHART_TITLE_DEFAULT = "Mittlere Sohlhöhe";
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
72 public static final String I18N_XAXIS_LABEL_DEFAULT = "km";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
73 public static final String I18N_YAXIS_LABEL_DEFAULT = "mittlere Sohlhöhen [müNN]";
4449
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
74 public static final String I18N_W_YAXIS_LABEL =
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
75 "chart.longitudinal.section.yaxis.label";
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
76 public static final String I18N_W_YAXIS_LABEL_DEFAULT = "W [NN + m]";
4537
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
77 public static final String I18N_P_YAXIS_LABEL_DEFAULT = "Gepeilte Breite [m]";
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
78 public static final String I18N_P_YAXIS_LABEL =
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
79 "chart.bedheight_middle.sounding.yaxis.label";
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
80 public static final String I18N_Q_YAXIS_LABEL_DEFAULT = "Q [m\u00b3/s]";
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
81 public static final String I18N_Q_YAXIS_LABEL =
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
82 "chart.longitudinal.section.yaxis.second.label";
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
83
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
84 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
85 protected YAxisWalker getYAxisWalker() {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
86 return new YAxisWalker() {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
87 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
88 public int length() {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
89 return YAXIS.values().length;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
90 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
91
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
92 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
93 public String getId(int idx) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
94 YAXIS[] yaxes = YAXIS.values();
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
95 return yaxes[idx].toString();
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
96 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
97 };
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
98 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
99
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
100
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
101 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
102 * Returns the default title for this chart.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
103 *
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
104 * @return the default title for this chart.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
105 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
106 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
107 public String getDefaultChartTitle() {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
108 Object[] args = new Object[] {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
109 getRiverName()
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
110 };
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
111
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
112 return msg(I18N_CHART_TITLE, I18N_CHART_TITLE_DEFAULT, args);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
113 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
114
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
115
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
116 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
117 * Get internationalized label for the x axis.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
118 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
119 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
120 protected String getDefaultXAxisLabel() {
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
121 D4EArtifact flys = (D4EArtifact) master;
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
122
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
123 return msg(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
124 I18N_XAXIS_LABEL,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
125 I18N_XAXIS_LABEL_DEFAULT,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5864
diff changeset
126 new Object[] { RiverUtils.getRiver(flys).getName() });
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
127 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
128
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
129
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
130 @Override
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
131 protected String getDefaultYAxisLabel(int index) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
132 String label = "default";
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
133
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
134 if (index == YAXIS.H.idx) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
135 label = getHAxisLabel();
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
136 }
4449
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
137 else if (index == YAXIS.W.idx) {
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
138 D4EArtifact flys = (D4EArtifact) master;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5864
diff changeset
139 String unit = RiverUtils.getRiver(flys).getWstUnit().getName();
5683
545a6ace9a19 Fixed label for 'W' axis in middle bed height generator.
Raimund Renkert <rrenkert@intevation.de>
parents: 5668
diff changeset
140
545a6ace9a19 Fixed label for 'W' axis in middle bed height generator.
Raimund Renkert <rrenkert@intevation.de>
parents: 5668
diff changeset
141 label = msg(
5699
5fca0d0d8aac Use correct i18n string for y axis.
Raimund Renkert <rrenkert@intevation.de>
parents: 5683
diff changeset
142 I18N_W_YAXIS_LABEL,
5fca0d0d8aac Use correct i18n string for y axis.
Raimund Renkert <rrenkert@intevation.de>
parents: 5683
diff changeset
143 I18N_W_YAXIS_LABEL_DEFAULT,
5683
545a6ace9a19 Fixed label for 'W' axis in middle bed height generator.
Raimund Renkert <rrenkert@intevation.de>
parents: 5668
diff changeset
144 new Object[] { unit });
4449
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
145 }
4537
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
146 else if (index == YAXIS.P.idx) {
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
147 label = msg(I18N_P_YAXIS_LABEL, I18N_P_YAXIS_LABEL_DEFAULT);
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
148 }
6927
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
149 else if (index == YAXIS.Q.idx) {
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
150 label = msg(I18N_Q_YAXIS_LABEL, I18N_Q_YAXIS_LABEL_DEFAULT);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
151 }
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
152
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
153 return label;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
154 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
155
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
156
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
157 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
158 * Get internationalized label for the y axis.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
159 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
160 protected String getHAxisLabel() {
6168
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
161 D4EArtifact flys = (D4EArtifact) master;
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
162
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
163 String unit = RiverUtils.getRiver(flys).getWstUnit().getName();
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
164
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
165 return msg(I18N_YAXIS_LABEL,
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
166 I18N_YAXIS_LABEL_DEFAULT,
2441a8cc8f37 part of issue986: axis label includes correct wst-unit.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6167
diff changeset
167 new Object[] { unit });
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
168 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
169
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
170
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
171 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
172 * Produce output.
3269
b2ea89a665bc Fix issues in 'documentation'.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2715
diff changeset
173 * @param artifactAndFacet current facet.
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
174 * @param attr theme for facet
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
175 */
4142
0ac1158605bd Fix typo
Christian Lins <christian.lins@intevation.de>
parents: 4047
diff changeset
176 @Override
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
177 public void doOut(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
178 ArtifactAndFacet artifactAndFacet,
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: 6430
diff changeset
179 ThemeDocument attr,
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
180 boolean visible
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
181 ) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
182 String name = artifactAndFacet.getFacetName();
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
183
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
184 logger.debug("MiddleBedHeightGenerator.doOut: " + name);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
185
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
186 if (name == null) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
187 logger.error("No facet name for doOut(). No output generated!");
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
188 return;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
189 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
190
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
191 Facet facet = artifactAndFacet.getFacet();
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
192
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
193 if (facet == null) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
194 return;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
195 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
196
4537
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
197 Processor woutp = new WOutProcessor();
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
198 Processor bedp = new BedheightProcessor();
6927
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
199 Processor qoutp = new QOutProcessor();
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
200 if (woutp.canHandle(name)) {
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
201 woutp.doOut(this, artifactAndFacet, attr, visible, YAXIS.W.idx);
5668
ab5db981044c Enable the middle bedheight chart generator to draw W facets.
Raimund Renkert <rrenkert@intevation.de>
parents: 4537
diff changeset
202 }
6927
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
203 else if (qoutp.canHandle(name)) {
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
204 qoutp.doOut(this, artifactAndFacet, attr, visible, YAXIS.Q.idx);
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
205 }
0288db5e90d5 issue1455: Extract QOutProcessor, use it
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6926
diff changeset
206 else if (name.equals(MIDDLE_BED_HEIGHT_SINGLE) || name.equals(MIDDLE_BED_HEIGHT_EPOCH)) {
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
207 doHeightOut(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
208 (MiddleBedHeightData) artifactAndFacet.getData(context),
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
209 artifactAndFacet,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
210 attr,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
211 visible);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
212 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
213 else if (name.equals(MIDDLE_BED_HEIGHT_ANNOTATION)) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
214 doAnnotations(
5864
f2e46a668fe6 River artifacts: Renamed FLYSAnnotation to RiverAnnotation.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
215 (RiverAnnotation) artifactAndFacet.getData(context),
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
216 artifactAndFacet,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
217 attr,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
218 visible);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
219 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
220 else if (FacetTypes.IS.AREA(name)) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
221 doArea(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
222 artifactAndFacet.getData(context),
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
223 artifactAndFacet,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
224 attr,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
225 visible);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
226 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
227 else if (FacetTypes.IS.MANUALPOINTS(name)) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
228 doPoints(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
229 artifactAndFacet.getData(context),
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
230 artifactAndFacet,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
231 attr,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
232 visible,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
233 YAXIS.H.idx);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
234 }
6430
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
235 else if (name.equals(LONGITUDINAL_ANNOTATION)) {
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
236 doAnnotations(
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
237 (RiverAnnotation) artifactAndFacet.getData(context),
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
238 artifactAndFacet,
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
239 attr,
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
240 visible);
641fd5bd6965 Enable annotations in mean bed height longitudinal section diagramm.
Tom Gottfried <tom@intevation.de>
parents: 6212
diff changeset
241 }
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
242 else if (name.equals(STATIC_WQKMS_Q)) {
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
243 doQOut(
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
244 (WQKms) artifactAndFacet.getData(context),
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
245 artifactAndFacet,
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
246 attr,
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
247 visible);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
248 }
4537
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
249 else if (bedp.canHandle(name)) {
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
250 bedp.doOut(this, artifactAndFacet, attr, visible, YAXIS.P.idx);
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
251 }
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
252 else if (woutp.canHandle(name)) {
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
253 woutp.doOut(this, artifactAndFacet, attr, visible, YAXIS.W.idx);
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
254 }
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
255 else {
4537
d337c67b6845 Handle also sounding width generated via the datacage in MiddleBedHeightGenerator
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4449
diff changeset
256 logger.warn("Unknown facet name: " + name);
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
257 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
258 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
259
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
260
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
261 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
262 * @param data A data object
3270
4ac581062c40 Fix various documentation issues.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 3269
diff changeset
263 * @param aandf The artifact and facet. This facet does NOT support any data objects. Use
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
264 * D4EArtifact.getNativeFacet() instead to retrieve a Facet which supports
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
265 * data.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
266 * @param theme The theme that contains styling information.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
267 * @param visible The visibility of the curve.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
268 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
269 protected void doHeightOut(
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
270 MiddleBedHeightData data,
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
271 ArtifactAndFacet aandf,
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: 6430
diff changeset
272 ThemeDocument theme,
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
273 boolean visible
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
274 ) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
275 logger.debug("MiddleBedHeightGenerator.doMainChannelOut");
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
276
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
277 XYSeries series = new StyledXYSeries(aandf.getFacetDescription(), theme);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
278
6212
128686fa5add flys/issue863: Create gaps for middlebedheight data if distance > 110 m.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6168
diff changeset
279 StyledSeriesBuilder.addPoints(series, data.getMiddleHeightsPoints(), false, 0.110d);
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
280
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
281 addAxisSeries(series, YAXIS.H.idx, visible);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
282 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
283
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
284
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
285 /** Look up the axis identifier for a given facet type. */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
286 public int axisIdxForFacet(String facetName) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
287 if (FacetTypes.IS.H(facetName)) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
288 return YAXIS.H.idx;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
289 }
4449
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
290 else if (FacetTypes.IS.W(facetName)) {
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
291 return YAXIS.W.idx;
f3c4976874f2 Add datacage for minfo and longitudinal_section.w from fixanalysis
Björn Ricks <bjoern.ricks@intevation.de>
parents: 4150
diff changeset
292 }
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
293 else {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
294 logger.warn("Could not find axis for facet " + facetName);
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
295 return YAXIS.H.idx;
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
296 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
297 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
298
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
299
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
300 /**
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
301 * Do Area out.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
302 * @param theme styling information.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
303 * @param visible whether or not visible.
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
304 */
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
305 protected void doArea(
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: 6430
diff changeset
306 Object o,
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
307 ArtifactAndFacet aandf,
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: 6430
diff changeset
308 ThemeDocument theme,
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6430
diff changeset
309 boolean visible
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
310 ) {
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
311 logger.debug("FlowVelocityGenerator.doArea");
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
312 logger.warn("TODO: Implement FlowVelocityGenerator.doArea");
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
313 }
6926
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
314
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
315
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
316 // TODO method borrowed from LongitudinalSectionGenerator.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
317 // Extract in an Processor
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
318 /**
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
319 * Process the output for Q facets in a longitudinal section curve.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
320 *
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
321 * @param wqkms An array of WQKms values.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
322 * @param aandf The facet and artifact. This facet does NOT support any data objects. Use
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
323 * D4EArtifact.getNativeFacet() instead to retrieve a Facet which supports
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
324 * data.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
325 * @param theme The theme that contains styling information.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
326 * @param visible The visibility of the curve.
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
327 */
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
328 protected void doQOut(
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
329 WQKms wqkms,
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
330 ArtifactAndFacet aandf,
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
331 ThemeDocument theme,
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
332 boolean visible
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
333 ) {
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
334 logger.debug("MiddleBedHeightGenerator.doQOut");
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
335
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
336 XYSeries series = new StyledXYSeries(aandf.getFacetDescription(), theme);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
337
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
338 StyledSeriesBuilder.addStepPointsKmQ(series, wqkms);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
339
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
340 addAxisSeries(series, YAXIS.Q.idx, visible);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
341
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
342 /*
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
343 if (needInvertAxis(wqkms)) {
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
344 setInverted(true);
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
345 }
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
346 */
bf191baa37e7 issue1455: Prepare MiddleBedHeightDiagram to show Q values.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
347 }
2715
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
348 }
250a370c377d Added chart generator for middle bed height charts.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
349 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org