annotate artifacts/src/main/java/org/dive4elements/river/artifacts/services/DischargeTablesOverview.java @ 9588:c57caff9b00b

Punkt 10.6 CSV-Ausgabe Abflusszeitreihenlänge
author gernotbelger
date Thu, 10 Jan 2019 11:56:39 +0100
parents 740d65e4aa14
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: 5431
diff changeset
9 package org.dive4elements.river.artifacts.services;
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
11 import java.awt.Color;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
12 import java.text.DateFormat;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
13 import java.text.ParseException;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
14 import java.util.ArrayList;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
15 import java.util.Collections;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
16 import java.util.Date;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
17 import java.util.List;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
18 import java.util.Locale;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
19
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
20 import org.apache.log4j.Logger;
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
21 import org.dive4elements.artifacts.CallMeta;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
22 import org.dive4elements.artifacts.GlobalContext;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
23 import org.dive4elements.river.artifacts.model.DischargeTables;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
24 import org.dive4elements.river.artifacts.model.GaugesFactory;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
25 import org.dive4elements.river.artifacts.resources.Resources;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
26 import org.dive4elements.river.backend.SessionHolder;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
27 import org.dive4elements.river.model.DischargeTable;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
28 import org.dive4elements.river.model.Gauge;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
29 import org.dive4elements.river.model.MainValue;
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
30 import org.dive4elements.river.model.TimeInterval;
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
31 import org.jfree.chart.ChartFactory;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
32 import org.jfree.chart.JFreeChart;
5344
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
33 import org.jfree.chart.plot.Marker;
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
34 import org.jfree.chart.plot.PlotOrientation;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
35 import org.jfree.chart.plot.XYPlot;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
36 import org.jfree.data.xy.XYSeries;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
37 import org.jfree.data.xy.XYSeriesCollection;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
38 import org.w3c.dom.Document;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
39 import org.w3c.dom.Element;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
40 import org.w3c.dom.NodeList;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
41
5342
7b119fa1e29f Doc and vim-magiv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4230
diff changeset
42 /** Generate Discharge Table chart. */
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
43 public class DischargeTablesOverview extends AbstractChartService {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
44
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
45 private static final Logger log = Logger.getLogger(DischargeTablesOverview.class);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
46
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
47 private static final long serialVersionUID = 1L;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
48
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
49 public static final String I18N_CHART_TITLE = "gauge.discharge.service.chart.title";
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
50 public static final String DEFAULT_CHART_TITLE = "Pegel: XXX";
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
51
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
52 public static final String I18N_CHART_X_AXIS_TITLE = "common.export.csv.header.q";
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
53 public static final String DEFAULT_X_AXIS_TITLE = "Q [m^3/s]";
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
54
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
55 public static final String I18N_CHART_Y_AXIS_TITLE = "gauge.discharge.service.chart.y.title";
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
56 public static final String DEFAULT_Y_AXIS_TITLE = "W [cm]";
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
57
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
58 public static final String I18N_CHART_SERIES_TITLE = "gauge.discharge.service.chart.series.title";
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
59 public static final String DEFAULT_CHART_SERIES_TITLE = "Abflusskurve";
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
60
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
61 public static final String I18N_CHART_SERIES_TITLE_MASTER = "gauge.discharge.service.chart.series.title.master";
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
62 public static final String DEFAULT_CHART_SERIES_TITLE_MASTER = "Aktuelle Abflusskurve";
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
63
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
64 public static final DateFormat DATE_FORMAT = DateFormat.getDateInstance(DateFormat.SHORT, Locale.GERMANY);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
65
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
66 @Override
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
67 protected void init() {
8572
321d6e50aebe Remove superfluous private variable.
Tom Gottfried <tom@intevation.de>
parents: 8566
diff changeset
68 SessionHolder.acquire();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
69 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
70
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
71 @Override
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
72 protected void finish() {
8566
fe7e9da6312a (issue1797) Move close into session release and guard it.
Andre Heinecke <andre.heinecke@intevation.de>
parents: 6301
diff changeset
73 SessionHolder.release();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
74 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
75
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
76 @Override
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
77 protected JFreeChart createChart(final Document data, final GlobalContext globalContext, final CallMeta callMeta) {
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
78
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
79 final Gauge gauge = extractGauge(data);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
80
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
81 if (gauge == null) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
82 log.warn("Could not determine Gauge from request!");
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
83 return null;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
84 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
85
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
86 log.info("create discharge chart for gauge '" + gauge.getName() + "'");
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
87 final TimeInterval timerange = extractTimeInterval(data);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
88
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
89 final List<DischargeTable> dts = getDischargeTables(gauge, timerange);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
90 final XYSeriesCollection dataset = new XYSeriesCollection();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
91
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
92 for (final DischargeTable dt : dts) {
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
93 try {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
94 final XYSeries series = createSeries(callMeta, dt);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
95 if (series != null) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
96 dataset.addSeries(series);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
97 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
98 }
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
99 catch (final IllegalArgumentException iae) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
100 log.warn("unable to create discharge curve: " + iae.getMessage());
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
101 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
102 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
103
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
104 final String title = Resources.format(callMeta, I18N_CHART_TITLE, DEFAULT_CHART_TITLE, gauge.getName());
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
105
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
106 final String xAxis = Resources.getMsg(callMeta, I18N_CHART_X_AXIS_TITLE, DEFAULT_X_AXIS_TITLE);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
107
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
108 final String yAxis = Resources.format(callMeta, I18N_CHART_Y_AXIS_TITLE, DEFAULT_Y_AXIS_TITLE);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
109
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
110 final JFreeChart chart = ChartFactory.createXYLineChart(title, xAxis, yAxis, null, PlotOrientation.VERTICAL, true, true, false);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
111
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
112 chart.setBackgroundPaint(Color.white);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
113
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
114 final XYPlot plot = (XYPlot) chart.getPlot();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
115 plot.setDataset(0, dataset);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
116 plot.setBackgroundPaint(Color.white);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
117 plot.setDomainGridlinePaint(Color.gray);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
118 plot.setRangeGridlinePaint(Color.gray);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
119 plot.setDomainGridlinesVisible(true);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
120 plot.setRangeGridlinesVisible(true);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
121
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
122 applyMainValueMarkers(plot, gauge, callMeta);
5344
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
123
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
124 return chart;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
125 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
126
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
127 protected XYSeries createSeries(final CallMeta callMeta, final DischargeTable dt) throws IllegalArgumentException {
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
128
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
129 double[][] xy = null;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
130
6301
20a32dbdbb59 Remove discharge table scaling but add reference system to W
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
131 xy = DischargeTables.loadDischargeTableValues(dt);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
132
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
133 final XYSeries series = new XYSeries(createSeriesTitle(callMeta, dt), false);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
134 for (int i = 0, n = xy[0].length; i < n; i++) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
135 series.add(xy[0][i], xy[1][i]);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
136 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
137
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
138 return series;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
139 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
140
5360
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
141 /** Add domain markers to plot that indicate mainvalues. */
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
142 protected static void applyMainValueMarkers(final XYPlot plot, final Gauge gauge, final CallMeta meta) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
143 final String river = gauge.getRiver().getName();
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
144 final double km = gauge.getStation().doubleValue();
5344
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
145
5360
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
146 // Get Gauge s mainvalues.
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
147 final List<MainValue> mainValues = gauge.getMainValues();
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
148 for (final MainValue mainValue : mainValues) {
5360
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
149 if (mainValue.getMainValue().getType().getName().equals("Q")) {
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
150 // Its a Q main value.
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
151 final Marker m = FixingsKMChartService.createQSectorMarker(mainValue.getValue().doubleValue(), mainValue.getMainValue().getName());
5344
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
152 plot.addDomainMarker(m);
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
153 } else if (mainValue.getMainValue().getType().getName().equals("W")) {
5360
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
154 // Its a W main value.
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
155 final Marker m = FixingsKMChartService.createQSectorMarker(mainValue.getValue().doubleValue(), mainValue.getMainValue().getName());
5360
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
156 plot.addRangeMarker(m);
02f6741f80d4 DischargeTablesOverview: Show main values from gauge in dischargetablesoverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5344
diff changeset
157 }
5344
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
158 }
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
159 }
f987d25627aa Show some Q mainvalues in DischargeTablesOverview.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5342
diff changeset
160
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
161 protected String createSeriesTitle(final CallMeta callMeta, final DischargeTable dt) throws IllegalArgumentException {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
162 final TimeInterval timeInterval = dt.getTimeInterval();
4227
8138a90a674a Be more tolerant with empty time intervals in discharge tables while comparing discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4217
diff changeset
163
8138a90a674a Be more tolerant with empty time intervals in discharge tables while comparing discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4217
diff changeset
164 if (timeInterval == null) {
8138a90a674a Be more tolerant with empty time intervals in discharge tables while comparing discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4217
diff changeset
165 return Resources.format(callMeta, DEFAULT_CHART_SERIES_TITLE);
8138a90a674a Be more tolerant with empty time intervals in discharge tables while comparing discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4217
diff changeset
166 }
8138a90a674a Be more tolerant with empty time intervals in discharge tables while comparing discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4217
diff changeset
167
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
168 final Date start = timeInterval.getStartTime();
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
169 final Date end = timeInterval.getStopTime();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
170
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
171 if (start != null && end != null) {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
172 return Resources.format(callMeta, I18N_CHART_SERIES_TITLE, DEFAULT_CHART_SERIES_TITLE, start, end);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
173 } else if (start != null) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
174 return Resources.format(callMeta, I18N_CHART_SERIES_TITLE_MASTER, DEFAULT_CHART_SERIES_TITLE, start);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
175 } else {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
176 throw new IllegalArgumentException("Missing start date of DischargeTable " + dt.getId());
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
177 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
178 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
179
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
180 protected Gauge extractGauge(final Document data) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
181 final NodeList gauges = data.getElementsByTagName("gauge");
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
182
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
183 if (gauges.getLength() > 0) {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
184 final String name = ((Element) gauges.item(0)).getAttribute("name");
4217
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
185
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
186 try {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
187 final long officialNumber = Long.valueOf(name);
4217
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
188 return Gauge.getGaugeByOfficialNumber(officialNumber);
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
189 }
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
190 catch (final NumberFormatException nfe) {
4217
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
191 // it seems, that the client uses the name of the gauge instead
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
192 // of its official number
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
193 }
08b6458909a9 The service 'DischargeTablesOverview' now accepts the official number of a gauge, too.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4213
diff changeset
194
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
195 if (name != null && name.length() > 0) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
196 return GaugesFactory.getGauge(name);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
197 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
198 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
199
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
200 return null;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
201 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
202
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
203 protected TimeInterval extractTimeInterval(final Document data) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
204 final NodeList timeranges = data.getElementsByTagName("timerange");
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
205
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
206 if (timeranges != null && timeranges.getLength() > 0) {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
207 final Element timerange = (Element) timeranges.item(0);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
208
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
209 final String lower = timerange.getAttribute("lower");
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
210 final String upper = timerange.getAttribute("upper");
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
211
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
212 if (lower != null && upper != null) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
213 try {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
214 final Date d1 = DATE_FORMAT.parse(lower);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
215 final Date d2 = DATE_FORMAT.parse(upper);
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
216
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
217 return new TimeInterval(d1, d2);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
218 }
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
219 catch (final ParseException pe) {
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
220 log.warn("Wrong time format: " + pe.getMessage());
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
221 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
222 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
223 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
224
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
225 return null;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
226 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
227
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
228 protected List<DischargeTable> getDischargeTables(final Gauge gauge, final TimeInterval timerange) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
229 final List<DischargeTable> all = gauge.getDischargeTables();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
230 Collections.sort(all);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
231
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
232 if (timerange == null) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
233 return all;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
234 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
235
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
236 final List<DischargeTable> dts = new ArrayList<>(all.size());
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
237 final long startDate = timerange.getStartTime().getTime();
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
238 final long stopDate = timerange.getStopTime().getTime();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
239
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
240 for (final DischargeTable dt : all) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
241 final TimeInterval tmp = dt.getTimeInterval();
4230
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
242 if (tmp == null) {
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
243 // this should never happen because all discharge tables should
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
244 // have a time interval set!
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
245 continue;
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
246 }
eab85cf85b10 Ignore discharge table without time interval set while discharge tables overview chart creation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 4227
diff changeset
247
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
248 final Date start = tmp.getStartTime();
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
249 final Date stop = tmp.getStartTime();
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
250
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
251 if (start.getTime() > startDate && start.getTime() < stopDate) {
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
252 dts.add(dt);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
253 continue;
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
254 } else if (stop != null && stop.getTime() < stopDate && stop.getTime() > startDate) {
4213
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
255 dts.add(dt);
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
256 continue;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
257 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
258 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
259
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
260 return dts;
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
261 }
0674d89210f5 Added a new service to query a diagram with discharge tables.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
262 }
5342
7b119fa1e29f Doc and vim-magiv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4230
diff changeset
263 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org