annotate artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java @ 8202:e4606eae8ea5

sed src/**/*.java 's/logger/log/g'
author Sascha L. Teichmann <teichmann@intevation.de>
date Fri, 05 Sep 2014 12:58:17 +0200
parents 11bc2d6a2059
children 839032ac1523
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: 5587
diff changeset
9 package org.dive4elements.river.exports;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
11 import java.io.IOException;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
12 import java.io.OutputStream;
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
13 import java.text.DateFormat;
418
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
14 import java.text.NumberFormat;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
15 import java.util.ArrayList;
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
16 import java.util.Map;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
17 import java.util.HashMap;
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
18 import java.util.Date;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
19 import java.util.List;
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
20 import java.util.Locale;
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
21 import java.util.regex.Matcher;
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
22 import java.util.regex.Pattern;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
23
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
24 import org.apache.log4j.Logger;
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
25
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
26 import au.com.bytecode.opencsv.CSVWriter;
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
27
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
28 import gnu.trove.TDoubleArrayList;
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
29
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
30 import org.dive4elements.river.artifacts.model.ConstantWQKms;
4836
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
31
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
32 import net.sf.jasperreports.engine.JasperExportManager;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
33 import net.sf.jasperreports.engine.JasperFillManager;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
34 import net.sf.jasperreports.engine.JasperPrint;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
35 import net.sf.jasperreports.engine.JRException;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
36
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
37 import org.dive4elements.artifacts.Artifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
38 import org.dive4elements.artifacts.CallMeta;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
39 import org.dive4elements.artifacts.common.utils.Config;
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
40
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
41 import org.dive4elements.river.model.Gauge;
706
ddd8b37d5cd3 Removed dead code.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 701
diff changeset
42
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
43 import org.dive4elements.river.artifacts.access.FixRealizingAccess;
7620
22b9d2dfb4d2 Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7615
diff changeset
44 import org.dive4elements.river.artifacts.access.IsOfficialAccess;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
45 import org.dive4elements.river.artifacts.access.RangeAccess;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
46 import org.dive4elements.river.artifacts.FixationArtifact;
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
47 import org.dive4elements.river.artifacts.D4EArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
48 import org.dive4elements.river.artifacts.WINFOArtifact;
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
49 import org.dive4elements.river.artifacts.StaticWQKmsArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
50 import org.dive4elements.river.artifacts.model.CalculationResult;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
51 import org.dive4elements.river.artifacts.model.Segment;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
52 import org.dive4elements.river.artifacts.model.WQCKms;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
53 import org.dive4elements.river.artifacts.model.WQKms;
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
54 import org.dive4elements.river.artifacts.model.WstLine;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
55 import org.dive4elements.river.artifacts.model.WKmsJRDataSource;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
56 import org.dive4elements.river.artifacts.model.WQKmsResult;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
57 import org.dive4elements.river.artifacts.resources.Resources;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
58
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
59 import org.dive4elements.river.utils.RiverUtils;
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
60 import org.dive4elements.river.utils.RiverUtils.WQ_MODE;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5587
diff changeset
61 import org.dive4elements.river.utils.Formatter;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
62
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
63 /**
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
64 * Generates different output formats (wst, csv, pdf) of data that resulted from
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
65 * a waterlevel computation.
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
66 *
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
67 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
68 */
391
5d6988836f01 Added an exporter to export the computed data of a duration curve.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 389
diff changeset
69 public class WaterlevelExporter extends AbstractExporter {
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
70
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
71 /** The log used in this exporter.*/
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
72 private static Logger log = Logger.getLogger(WaterlevelExporter.class);
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
73
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
74 public static final String FACET_WST = "wst";
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
75
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
76 /* This should be the same as in the StaticWQKmsArtifact */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
77 public static final String STATICWQKMSNAME = "staticwqkms";
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
78
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
79 public static final String CSV_KM_HEADER =
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
80 "export.waterlevel.csv.header.km";
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
81
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
82 public static final String CSV_W_HEADER =
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
83 "export.waterlevel.csv.header.w";
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
84
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
85 public static final String CSV_Q_HEADER =
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
86 "export.waterlevel.csv.header.q";
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
87
2063
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
88 public static final String CSV_Q_DESC_HEADER =
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
89 "export.waterlevel.csv.header.q.desc";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
90
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
91 public static final String CSV_W_DESC_HEADER =
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
92 "export.waterlevel.csv.header.w.desc";
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
93
2063
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
94 public static final String CSV_LOCATION_HEADER =
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
95 "export.waterlevel.csv.header.location";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
96
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
97 public static final String CSV_GAUGE_HEADER =
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
98 "export.waterlevel.csv.header.gauge";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
99
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
100 public static final String CSV_META_RESULT =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
101 "export.waterlevel.csv.meta.result";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
102
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
103 public static final String CSV_META_CREATION =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
104 "export.waterlevel.csv.meta.creation";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
105
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
106 public static final String CSV_META_CALCULATIONBASE =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
107 "export.waterlevel.csv.meta.calculationbase";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
108
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
109 public static final String CSV_META_RIVER =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
110 "export.waterlevel.csv.meta.river";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
111
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
112 public static final String CSV_META_RANGE =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
113 "export.waterlevel.csv.meta.range";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
114
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
115 public static final String CSV_META_GAUGE =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
116 "export.waterlevel.csv.meta.gauge";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
117
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
118 public static final String CSV_META_Q =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
119 "export.waterlevel.csv.meta.q";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
120
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
121 public static final String CSV_META_W =
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
122 "export.waterlevel.csv.meta.w";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
123
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
124 public static final String CSV_NOT_IN_GAUGE_RANGE =
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
125 "export.waterlevel.csv.not.in.gauge.range";
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
126
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
127 public static final Pattern NUMBERS_PATTERN =
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
128 Pattern.compile("\\D*(\\d++.\\d*)\\D*");
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
129
2063
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
130 public static final String DEFAULT_CSV_KM_HEADER = "Fluss-Km";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
131 public static final String DEFAULT_CSV_W_HEADER = "W [NN + m]";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
132 public static final String DEFAULT_CSV_Q_HEADER = "Q [m\u00b3/s]";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
133 public static final String DEFAULT_CSV_Q_DESC_HEADER = "Bezeichnung";
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
134 public static final String DEFAULT_CSV_W_DESC_HEADER = "W/Pegel [cm]";
2063
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
135 public static final String DEFAULT_CSV_LOCATION_HEADER = "Lage";
97a25b54eea3 Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2045
diff changeset
136 public static final String DEFAULT_CSV_GAUGE_HEADER = "Bezugspegel";
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
137 public static final String DEFAULT_CSV_NOT_IN_GAUGE_RANGE =
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
138 "außerhalb des gewählten Bezugspegels";
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
139
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
140 public static final String PDF_HEADER_MODE = "export.waterlevel.pdf.mode";
2284
5d1ba04d2f68 Refactored Formatter access to ease reuse.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2185
diff changeset
141 public static final String JASPER_FILE = "export.waterlevel.pdf.file";
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
142
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
143 /** The storage that contains all WQKms objects that are calculated.*/
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
144 protected List<WQKms[]> data;
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
145
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
146 /** The storage that contains official fixings if available.*/
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
147 protected List<WQKms> officalFixings;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
148
7077
0a337f0005c2 Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6941
diff changeset
149 public WaterlevelExporter() {
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
150 data = new ArrayList<WQKms[]>();
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
151 }
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
152
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
153 @Override
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
154 public void generate()
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
155 throws IOException
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
156 {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
157 log.debug("WaterlevelExporter.generate");
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
158
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
159 /* Check for official fixings. They should also be included in the
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
160 * export but only the calculation result is added with addData */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
161
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
162 officalFixings = new ArrayList<WQKms>();
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
163
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
164 for (Artifact art: collection.getArtifactsByName(STATICWQKMSNAME, context)) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
165 if (art instanceof StaticWQKmsArtifact) {
7620
22b9d2dfb4d2 Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7615
diff changeset
166 IsOfficialAccess access = new IsOfficialAccess((D4EArtifact)art);
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
167 StaticWQKmsArtifact sart = (StaticWQKmsArtifact) art;
7620
22b9d2dfb4d2 Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7615
diff changeset
168 if (!access.isOfficial()) {
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
169 continue;
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
170 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
171
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
172 /* Check that we add the data only once */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
173 WQKms toAdd = sart.getWQKms();
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
174 String newName = toAdd.getName();
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
175
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
176 boolean exists = false;
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
177 for (WQKms wqkm: officalFixings) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
178 /* The same official fixing could be in two
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
179 artifacts/outs so let's deduplicate */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
180 if (wqkm.getName().equals(newName)) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
181 exists = true;
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
182 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
183 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
184 if (!exists) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
185 officalFixings.add(toAdd);
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
186 log.debug("Adding additional offical fixing: " + newName);
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
187 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
188 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
189 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
190
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
191 if (facet != null && facet.equals(AbstractExporter.FACET_CSV)) {
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
192 generateCSV();
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
193 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
194 else if (facet != null && facet.equals(FACET_WST)) {
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
195 generateWST();
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
196 }
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
197 else if (facet != null && facet.equals(AbstractExporter.FACET_PDF)) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
198 generatePDF();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
199 }
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
200 else {
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
201 throw new IOException("invalid facet for exporter");
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
202 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
203 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
204
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
205
701
dad1a2c88f9f Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 664
diff changeset
206 @Override
dad1a2c88f9f Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 664
diff changeset
207 protected void addData(Object d) {
709
3b7e9ddf6bb1 New model to transport data and error reports of calculations.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 707
diff changeset
208 if (d instanceof CalculationResult) {
3b7e9ddf6bb1 New model to transport data and error reports of calculations.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 707
diff changeset
209 d = ((CalculationResult)d).getData();
3b7e9ddf6bb1 New model to transport data and error reports of calculations.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 707
diff changeset
210 if (d instanceof WQKms []) {
3b7e9ddf6bb1 New model to transport data and error reports of calculations.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 707
diff changeset
211 data.add((WQKms [])d);
3b7e9ddf6bb1 New model to transport data and error reports of calculations.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 707
diff changeset
212 }
4405
7e7587c905ab WaterlevelExporter: Use new WQKmsResult to avoid parallel paths for Extrem- and Fixing-Result.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 3462
diff changeset
213 else if (d instanceof WQKmsResult) {
7e7587c905ab WaterlevelExporter: Use new WQKmsResult to avoid parallel paths for Extrem- and Fixing-Result.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 3462
diff changeset
214 data.add(((WQKmsResult) d).getWQKms());
3462
13855a555d3b Added new Output WaterlevelExport (CSV, WST and PDF) to FixRealizingCompute State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 3313
diff changeset
215 }
701
dad1a2c88f9f Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 664
diff changeset
216 }
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
217 }
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
218
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
219
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
220 /**
6576
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6101
diff changeset
221 * Prepare the column titles of waterlevel exports.
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
222 * Titles in this export include the Q value. If a Q value matches a named
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
223 * main value (as HQ100 or MNQ) this named main value should be used as
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
224 * title. This method resets the name of the <i>wqkms</i> object if such
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
225 * named main value fits to the chosen Q.
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
226 *
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
227 * @param winfo A WINFO Artifact.
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
228 * @param wqkms A WQKms object that should be prepared.
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
229 */
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
230 protected String getColumnTitle(WINFOArtifact winfo, WQKms wqkms) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
231 log.debug("WaterlevelExporter.getColumnTitle");
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
232
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
233 String name = wqkms.getName();
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
234
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
235 log.debug("Name of WQKms = '" + name + "'");
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
236
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
237 if (name.indexOf("W=") >= 0) {
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
238 return name;
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
239 }
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
240
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
241 Matcher m = NUMBERS_PATTERN.matcher(name);
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
242
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
243 if (m.matches()) {
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
244 String raw = m.group(1);
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
245
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
246 try {
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
247 double v = Double.valueOf(raw);
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
248
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
249 String nmv = RiverUtils.getNamedMainValue(winfo, v);
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
250
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
251 if (nmv != null && nmv.length() > 0) {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
252 nmv = RiverUtils.stripNamedMainValue(nmv);
2596
00cf69edfcc0 #252 Added numeric value of a named main value into the WST export.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2423
diff changeset
253 nmv += "=" + String.valueOf(v);
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
254 log.debug("Set named main value '" + nmv + "'");
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
255
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
256 return nmv;
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
257 }
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
258 }
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
259 catch (NumberFormatException nfe) {
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
260 // do nothing here
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
261 }
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
262 }
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
263
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
264 return name;
2035
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
265 }
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
266
3ebbe497d7f7 #252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 749
diff changeset
267
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
268 protected String getCSVRowTitle(WINFOArtifact winfo, WQKms wqkms) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
269 log.debug("WaterlevelExporter.prepareNamedValue");
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
270
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
271 String name = wqkms.getName();
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
272
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
273 log.debug("Name of WQKms = '" + name + "'");
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
274
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
275 WQ_MODE wqmode = RiverUtils.getWQMode(winfo);
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
276
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
277 if (wqmode == WQ_MODE.WFREE || wqmode == WQ_MODE.QGAUGE) {
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
278 return localizeWQKms(winfo, wqkms);
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
279 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
280
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
281 Double v = wqkms.getRawValue();
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
282
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
283 String nmv = RiverUtils.getNamedMainValue(winfo, v);
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
284
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
285 if (nmv != null && nmv.length() > 0) {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
286 nmv = RiverUtils.stripNamedMainValue(nmv);
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
287 log.debug("Set named main value '" + nmv + "'");
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
288
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
289 return nmv;
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
290 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
291
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
292 return localizeWQKms(winfo, wqkms);
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
293 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
294
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
295
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
296 /**
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
297 * Get a string like 'W=' or 'Q=' with a number following in localized
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
298 * format.
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
299 */
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
300 protected String localizeWQKms(WINFOArtifact winfo, WQKms wqkms) {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
301 WQ_MODE wqmode = RiverUtils.getWQMode(winfo);
2087
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
302 Double rawValue = wqkms.getRawValue();
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
303
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
304 if (rawValue == null) {
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
305 return wqkms.getName();
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
306 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
307
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
308 NumberFormat nf = Formatter.getRawFormatter(context);
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
309
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
310 if (wqmode == WQ_MODE.WFREE || wqmode == WQ_MODE.WGAUGE) {
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
311 return "W=" + nf.format(rawValue);
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
312 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
313 else {
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
314 return "Q=" + nf.format(rawValue);
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
315 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
316 }
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
317
bda04ae1154f #196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2068
diff changeset
318
701
dad1a2c88f9f Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 664
diff changeset
319 @Override
391
5d6988836f01 Added an exporter to export the computed data of a duration curve.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 389
diff changeset
320 protected void writeCSVData(CSVWriter writer) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
321 log.info("WaterlevelExporter.writeData");
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
322
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
323 WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact)master);
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
324 boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE;
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
325 boolean isQ = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
326 RiverUtils.WQ_INPUT input
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
327 = RiverUtils.getWQInputMode((D4EArtifact)master);
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
328
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
329 writeCSVMeta(writer);
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
330 writeCSVHeader(writer, atGauge, isQ);
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
331
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
332 Double first = Double.NaN;
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
333 Double last = Double.NaN;
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
334
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
335 for (WQKms[] tmp: data) {
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
336 for (WQKms wqkms: tmp) {
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
337 wQKms2CSV(writer, wqkms, atGauge, isQ);
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
338 double[] firstLast = wqkms.getFirstLastKM();
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
339 if (first.isNaN()) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
340 /* Initialize */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
341 first = firstLast[0];
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
342 last = firstLast[1];
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
343 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
344 if (firstLast[0] > firstLast[1]) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
345 /* Calculating upstream we assert that it is
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
346 * impossible that the direction changes during this
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
347 * loop */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
348 first = Math.max(first, firstLast[0]);
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
349 last = Math.min(last, firstLast[1]);
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
350 } else if (firstLast[0] < firstLast[1]) {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
351 first = Math.min(first, firstLast[0]);
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
352 last = Math.max(last, firstLast[1]);
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
353 } else {
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
354 first = last = firstLast[0];
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
355 }
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
356 }
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
357 }
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
358 /* Append the official fixing at the bottom */
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
359 for (WQKms wqkms: officalFixings) {
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
360 wQKms2CSV(writer, filterWQKms(wqkms, first, last), atGauge, isQ);
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
361 }
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
362 }
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
363
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
364
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
365 /** Filter a wqkms object to a distance.
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
366 *
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
367 * To handle upstream / downstream and to limit
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
368 * the officialFixings to the calculation distance
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
369 * we create a new wqkms object here and fill it only
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
370 * with the relevant data.
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
371 *
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
372 * @param wqkms: The WQKms Object to filter
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
373 * @param first: The fist kilometer of the range
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
374 * @param last: The last kilometer of the range
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
375 *
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
376 * @return A new WQKms with the relevant data sorted by direction
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
377 */
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
378 private WQKms filterWQKms(WQKms wqkms, Double first, Double last) {
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
379 if (first.isNaN() || last.isNaN()) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
380 log.warn("Filtering official fixing without valid first/last.");
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
381 return wqkms;
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
382 }
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
383 int firstIdx = first > last ? wqkms.size() - 1 : 0;
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
384 int lastIdx = first > last ? 0 : wqkms.size() -1;
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
385 WQKms filtered = new WQKms (wqkms.size());
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
386 filtered.setReferenceSystem(wqkms.getReferenceSystem());
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
387 filtered.setName(wqkms.getName());
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
388 double [] dp = new double [3];
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
389
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
390 if (first > last) {
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
391 for (int i = wqkms.size() - 1; i >= 0; i--) {
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
392 dp = wqkms.get(i, dp);
6605
ddef735db96a Include the calculation borders in the official line export.
Andre Heinecke <aheinecke@intevation.de>
parents: 6603
diff changeset
393 if (dp[2] <= first + 1E-5 && dp[2] > last - 1E-5) {
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
394 filtered.add(dp[0], dp[1], dp[2]);
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
395 }
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
396 }
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
397 } else {
7254
fe32a7f9655e Reduce usage of careless 'for (int i = 0; i < x.size(); i++)' pattern.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7088
diff changeset
398 for (int i = 0, N = wqkms.size(); i < N; i++) {
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
399 dp = wqkms.get(i, dp);
6605
ddef735db96a Include the calculation borders in the official line export.
Andre Heinecke <aheinecke@intevation.de>
parents: 6603
diff changeset
400 if (dp[2] < last + 1E-5 && dp[2] > first - 1E-5) {
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
401 filtered.add(dp[0], dp[1], dp[2]);
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
402 }
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
403 }
6601
5ecc6d4d73f2 Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents: 6576
diff changeset
404 }
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
405 return filtered;
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
406 }
6603
90756201c488 Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents: 6601
diff changeset
407
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
408
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
409 protected void writeCSVMeta(CSVWriter writer) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
410 log.info("WaterlevelExporter.writeCSVMeta");
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
411
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
412 // TODO use Access instead of RiverUtils
4859
e31231d0a720 WaterlevelExporter: Updated to use RangeAccess instead of FLYSUtils.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4836
diff changeset
413
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
414 CallMeta meta = context.getMeta();
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
415
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
416 D4EArtifact flys = (D4EArtifact) master;
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
417
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
418 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
419 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
420 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
421 CSV_META_RESULT,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
422 CSV_META_RESULT,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
423 new Object[] { RiverUtils.getRivername(flys) })
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
424 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
425
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
426 Locale locale = Resources.getLocale(meta);
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
427 DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT, locale);
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
428
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
429 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
430 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
431 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
432 CSV_META_CREATION,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
433 CSV_META_CREATION,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
434 new Object[] { df.format(new Date()) })
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
435 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
436
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
437 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
438 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
439 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
440 CSV_META_CALCULATIONBASE,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
441 CSV_META_CALCULATIONBASE,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
442 new Object[] { "" }) // TODO what is required at this place?
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
443 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
444
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
445 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
446 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
447 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
448 CSV_META_RIVER,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
449 CSV_META_RIVER,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
450 new Object[] { RiverUtils.getRivername(flys) })
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
451 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
452
6101
a0078e5e3b39 Removed unused context from RangeAccess and subclasses leading to some dead code removal.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6074
diff changeset
453 RangeAccess rangeAccess = new RangeAccess(flys);
4859
e31231d0a720 WaterlevelExporter: Updated to use RangeAccess instead of FLYSUtils.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4836
diff changeset
454 double[] kms = rangeAccess.getKmRange();
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
455 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
456 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
457 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
458 CSV_META_RANGE,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
459 CSV_META_RANGE,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
460 new Object[] { kms[0], kms[kms.length-1] })
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
461 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
462
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
463 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
464 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
465 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
466 CSV_META_GAUGE,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
467 CSV_META_GAUGE,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
468 new Object[] { RiverUtils.getGaugename(flys) })
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
469 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
470
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
471 RiverUtils.WQ_MODE wq = RiverUtils.getWQMode(flys);
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
472 if (wq == RiverUtils.WQ_MODE.QFREE || wq == RiverUtils.WQ_MODE.QGAUGE) {
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
473 double[] qs = RiverUtils.getQs(flys);
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
474 RiverUtils.WQ_INPUT input = RiverUtils.getWQInputMode(flys);
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
475
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
476 String data = "";
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
477
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
478 if ((input == RiverUtils.WQ_INPUT.ADAPTED ||
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
479 input == RiverUtils.WQ_INPUT.RANGE) &&
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
480 qs != null && qs.length > 0)
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
481 {
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
482 data = String.valueOf(qs[0]);
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
483 data += " - " + String.valueOf(qs[qs.length-1]);
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
484 }
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
485 else if (input == RiverUtils.WQ_INPUT.SINGLE && qs != null){
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
486 data = String.valueOf(qs[0]);
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
487 for (int i = 1; i < qs.length; i++) {
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
488 data += ", " + String.valueOf(qs[i]);
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
489 }
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
490 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
491 else {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
492 log.warn("Could not determine Q range!");
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
493 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
494
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
495 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
496 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
497 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
498 CSV_META_Q,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
499 CSV_META_Q,
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2290
diff changeset
500 new Object[] {data})
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
501 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
502 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
503 else {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
504 double[] ws = RiverUtils.getWs(flys);
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
505
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
506 String lower = "";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
507 String upper = "";
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
508
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
509 if (ws != null && ws.length > 0) {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
510 lower = String.valueOf(ws[0]);
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
511 upper = String.valueOf(ws[ws.length-1]);
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
512 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
513 else {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
514 log.warn("Could not determine W range!");
2045
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
515 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
516
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
517 writer.writeNext(new String[] {
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
518 Resources.getMsg(
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
519 meta,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
520 CSV_META_W,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
521 CSV_META_W,
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
522 new Object[] { lower, upper })
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
523 });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
524 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
525
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
526 writer.writeNext(new String[] { "" });
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
527 }
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
528
d13be39cfd1d #242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2038
diff changeset
529
4979
4c76c5f69eaf WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4859
diff changeset
530 /**
4c76c5f69eaf WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4859
diff changeset
531 * Write the header, with different headings depending on whether at a
4c76c5f69eaf WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4859
diff changeset
532 * gauge or at a location.
4c76c5f69eaf WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4859
diff changeset
533 */
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
534 protected void writeCSVHeader(
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
535 CSVWriter writer,
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
536 boolean atGauge,
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
537 boolean isQ
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
538 ) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
539 log.info("WaterlevelExporter.writeCSVHeader");
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
540
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
541 String unit = RiverUtils.getRiver((D4EArtifact) master).getWstUnit().getName();
5133
8e52b4829cd1 Fix flys/issue1228: Units in tabular calculation output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5131
diff changeset
542
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
543 if (atGauge) {
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
544 writer.writeNext(new String[] {
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
545 msg(CSV_KM_HEADER, DEFAULT_CSV_KM_HEADER),
5133
8e52b4829cd1 Fix flys/issue1228: Units in tabular calculation output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5131
diff changeset
546 msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER, new Object[] { unit }),
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
547 msg(CSV_Q_HEADER, DEFAULT_CSV_Q_HEADER),
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
548 (isQ
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
549 ? msg(CSV_Q_DESC_HEADER, DEFAULT_CSV_Q_DESC_HEADER)
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
550 : msg(CSV_W_DESC_HEADER, DEFAULT_CSV_W_DESC_HEADER)),
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
551 msg(CSV_LOCATION_HEADER, DEFAULT_CSV_LOCATION_HEADER),
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
552 msg(CSV_GAUGE_HEADER, DEFAULT_CSV_GAUGE_HEADER)
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
553 });
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
554 }
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
555 else {
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
556 writer.writeNext(new String[] {
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
557 msg(CSV_KM_HEADER, DEFAULT_CSV_KM_HEADER),
5133
8e52b4829cd1 Fix flys/issue1228: Units in tabular calculation output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5131
diff changeset
558 // TODO flys/issue1128 (unit per river)
8e52b4829cd1 Fix flys/issue1228: Units in tabular calculation output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5131
diff changeset
559 msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER, new Object[] { unit }),
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
560 msg(CSV_Q_HEADER, DEFAULT_CSV_Q_HEADER),
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
561 msg(CSV_LOCATION_HEADER, DEFAULT_CSV_LOCATION_HEADER)
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
562 });
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
563 }
416
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
564 }
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
565
340dc41a7ea3 The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 391
diff changeset
566
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
567 /** Linearly search for gauge which is valid at km. */
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
568 private static Gauge findGauge(double km, List<Gauge> gauges) {
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
569 for (Gauge gauge: gauges) {
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
570 if (gauge.getRange().contains(km)) {
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
571 return gauge;
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
572 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
573 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
574 return null;
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
575 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
576
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
577 private static Segment findSegment(double km, List<Segment> segments) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
578 for (Segment segment: segments) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
579 if (segment.inside(km)) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
580 return segment;
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
581 }
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
582 }
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
583 return null;
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
584 }
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
585
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
586
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
587 private void writeRow4(CSVWriter writer, double wqkm[], D4EArtifact flys) {
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
588 NumberFormat kmf = getKmFormatter();
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
589 NumberFormat wf = getWFormatter();
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
590 NumberFormat qf = getQFormatter();
6607
85ff19b94ec5 Indentation fix
Andre Heinecke <aheinecke@intevation.de>
parents: 6606
diff changeset
591 writer.writeNext(new String[] {
85ff19b94ec5 Indentation fix
Andre Heinecke <aheinecke@intevation.de>
parents: 6606
diff changeset
592 kmf.format(wqkm[2]),
85ff19b94ec5 Indentation fix
Andre Heinecke <aheinecke@intevation.de>
parents: 6606
diff changeset
593 wf.format(wqkm[0]),
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
594 qf.format(RiverUtils.roundQ(wqkm[1])),
6607
85ff19b94ec5 Indentation fix
Andre Heinecke <aheinecke@intevation.de>
parents: 6606
diff changeset
595 RiverUtils.getLocationDescription(flys, wqkm[2])
85ff19b94ec5 Indentation fix
Andre Heinecke <aheinecke@intevation.de>
parents: 6606
diff changeset
596 });
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
597 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
598
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
599 /** Write an csv-row at gauge location. */
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
600 private void writeRow6(CSVWriter writer, double wqkm[], String wOrQDesc,
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
601 D4EArtifact flys, String gaugeName) {
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
602 NumberFormat kmf = getKmFormatter();
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
603 NumberFormat wf = getWFormatter();
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
604 NumberFormat qf = getQFormatter();
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
605
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
606 writer.writeNext(new String[] {
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
607 kmf.format(wqkm[2]),
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
608 wf.format(wqkm[0]),
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
609 qf.format(RiverUtils.roundQ(wqkm[1])),
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
610 wOrQDesc,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
611 RiverUtils.getLocationDescription(flys, wqkm[2]),
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
612 gaugeName
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
613 });
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
614 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
615
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
616 private String getDesc(WQKms wqkms, boolean isQ)
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
617 {
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
618 D4EArtifact flys = (D4EArtifact) master;
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
619 String colDesc = "";
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
620
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
621 if (flys instanceof WINFOArtifact && isQ) {
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
622 colDesc = getCSVRowTitle((WINFOArtifact)flys, wqkms);
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
623 }
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
624 else if (!isQ) {
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
625 Double value = RiverUtils.getValueFromWQ(wqkms);
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
626 colDesc = (value != null) ?
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
627 Formatter.getWaterlevelW(context).format(value) : null;
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
628 }
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
629
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
630 if (flys instanceof WINFOArtifact) {
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
631 if (wqkms != null && wqkms.getRawValue() != null) {
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
632 WINFOArtifact winfo = (WINFOArtifact) flys;
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
633 colDesc = RiverUtils.getNamedMainValue(winfo, wqkms.getRawValue());
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
634 // For 'W am Pegel' s
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
635 if (colDesc == null) {
6634
b1e66ea7fc2b Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents: 6610
diff changeset
636 Double value = RiverUtils.getValueFromWQ(wqkms);
b1e66ea7fc2b Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents: 6610
diff changeset
637 colDesc = (value != null) ?
b1e66ea7fc2b Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents: 6610
diff changeset
638 Formatter.getWaterlevelW(context).format(value) : null;
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
639 }
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
640 }
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
641 }
6610
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
642 if (colDesc != null) {
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
643 /* Quick hack. Can be removed when database strings are
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
644 * adapted or left in here as it should never be harmful. */
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
645 colDesc = colDesc.replace("Amtl.Festlegung_", "Amtl. ");
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
646 }
8d88db1f5d36 Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents: 6608
diff changeset
647
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
648 return colDesc == null ? "" : colDesc;
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
649 }
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
650
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
651 /**
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
652 * Write "rows" of csv data from wqkms with writer.
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
653 */
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
654 protected void wQKms2CSV(
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
655 CSVWriter writer,
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
656 WQKms wqkms,
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
657 boolean atGauge,
3252
62c9bcef0680 Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2764
diff changeset
658 boolean isQ
2068
0cf60d64895c #370 Added a 'W at gauge' column to CSV exports if 'W at gauge' mode has been selected.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2066
diff changeset
659 ) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
660 log.debug("WaterlevelExporter.wQKms2CSV");
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
661
4836
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
662 // Skip constant data.
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
663 if (wqkms instanceof ConstantWQKms) {
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
664 return;
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
665 }
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
666
418
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
667 NumberFormat kmf = getKmFormatter();
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
668 NumberFormat wf = getWFormatter();
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
669 NumberFormat qf = getQFormatter();
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
670
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
671 int size = wqkms.size();
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
672 double[] result = new double[3];
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
673
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
674 D4EArtifact flys = (D4EArtifact) master;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
675 List<Gauge> gauges = RiverUtils.getGauges(flys);
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
676 Gauge gauge = RiverUtils.getGauge(flys);
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
677 String gaugeName = gauge.getName();
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
678 String desc = "";
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
679 String notinrange = msg(
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
680 CSV_NOT_IN_GAUGE_RANGE,
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
681 DEFAULT_CSV_NOT_IN_GAUGE_RANGE);
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
682 List<Segment> segments = null;
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
683 boolean isFixRealize = false;
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
684
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
685 double a = gauge.getRange().getA().doubleValue();
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
686 double b = gauge.getRange().getB().doubleValue();
2144
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
687 long startTime = System.currentTimeMillis();
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
688
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
689 desc = getDesc(wqkms, isQ);
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
690
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
691 if (flys instanceof FixationArtifact) {
5103
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
692 // Get W/Q input per gauge for this case.
6101
a0078e5e3b39 Removed unused context from RangeAccess and subclasses leading to some dead code removal.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6074
diff changeset
693 FixRealizingAccess fixAccess = new FixRealizingAccess(flys);
5103
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
694 segments = fixAccess.getSegments();
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
695 if (segments != null && !segments.isEmpty()) {
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
696 isFixRealize = true;
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
697 }
5103
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
698 }
2612
49cfa5c66651 Squashed performance bug introduced in rev4070. Now CSV export is about 245 times faster.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2596
diff changeset
699
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
700 if (atGauge) { // "At gauge" needs more output.
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
701
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
702 // Kms tend to be close together so caching the last sector
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
703 // is a good time saving heuristic.
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
704 Segment lastSegment = null;
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
705 Gauge lastGauge = null;
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
706
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
707 NumberFormat nf =
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
708 Formatter.getFormatter(context.getMeta(), 0, 0);
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
709
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
710 for (int i = 0; i < size; ++i) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
711 result = wqkms.get(i, result);
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
712 double km = result[2];
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
713
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
714 if (segments != null) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
715 Segment found = lastSegment != null
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
716 && lastSegment.inside(km)
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
717 ? lastSegment
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
718 : findSegment(km, segments);
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
719
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
720 if (found != null) {
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
721 desc = nf.format(found.getValues()[0]);
5103
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
722 }
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
723 lastSegment = found;
5103
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
724 }
15e856a64cdd Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4979
diff changeset
725
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
726 String gaugeN;
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
727 if (isFixRealize) {
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
728 Gauge found = lastGauge != null
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
729 && lastGauge.getRange().contains(km)
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
730 ? lastGauge
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
731 : findGauge(km, gauges);
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
732
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
733 gaugeN = found != null ? found.getName() : notinrange;
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
734 lastGauge = found;
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
735 }
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
736 else {
4979
4c76c5f69eaf WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4859
diff changeset
737 // TODO issue1114: Take correct gauge
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
738 gaugeN = km >= a && km <= b
2066
2b6a0de47379 Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2065
diff changeset
739 ? gaugeName
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
740 : notinrange;
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
741 }
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
742 writeRow6(writer, result, desc, flys, gaugeN);
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
743 }
5587
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
744 }
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
745 else { // Not at gauge.
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
746 for (int i = 0; i < size; ++i) {
7b1c5fe4ebf3 Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5425
diff changeset
747 result = wqkms.get(i, result);
5112
ae25e23a1546 WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 5107
diff changeset
748 writeRow4(writer, result, flys);
2065
2f5628f0de0e Part 2 of #125: add gaugename and Q description based on the selected WQ mode.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2063
diff changeset
749 }
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
750 }
2144
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
751
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
752 long stopTime = System.currentTimeMillis();
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
753
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
754 if (log.isDebugEnabled()) {
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
755 log.debug("Writing CSV took " +
2144
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
756 (float)(stopTime-startTime)/1000f + " secs.");
a4bdf7d8527e Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2087
diff changeset
757 }
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
758 }
418
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
759
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
760
e0fec407a280 ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 416
diff changeset
761 /**
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
762 * Generates the output in WST format.
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
763 */
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
764 protected void generateWST()
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
765 throws IOException
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
766 {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
767 log.info("WaterlevelExporter.generateWST");
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
768
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
769 int cols = data.get(0).length + officalFixings.size();
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
770 WstWriter writer = new WstWriter(cols);
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
771
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
772 writeWSTData(writer);
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
773
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
774 writer.write(out);
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
775 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
776
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
777
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
778 protected void writeWSTData(WstWriter writer) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
779 log.debug("WaterlevelExporter.writeWSTData");
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
780
749
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
781 double[] result = new double[4];
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
782
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
783 for (WQKms[] tmp: data) {
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
784 for (WQKms wqkms: tmp) {
5105
34baad34987f Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents: 5103
diff changeset
785 if (wqkms instanceof ConstantWQKms) {
34baad34987f Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents: 5103
diff changeset
786 continue;
34baad34987f Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents: 5103
diff changeset
787 }
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
788 int size = wqkms != null ? wqkms.size() : 0;
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
789
450
c8bb38115290 Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 447
diff changeset
790 addWSTColumn(writer, wqkms);
447
5606ba4139e0 WSTs will now have a header that contains the names of the Ws or Qs that had been defined for the computation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 446
diff changeset
791
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
792 for (int i = 0; i < size; i++) {
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
793 result = wqkms.get(i, result);
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
794
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
795 writer.add(result);
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
796 }
749
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
797
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
798 if (wqkms instanceof WQCKms) {
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
799 addWSTColumn(writer, wqkms);
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
800
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
801 for (int c = 0; c < size; c++) {
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
802 result = wqkms.get(c, result);
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
803
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
804 writer.addCorrected(result);
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
805 }
72bcbc308501 The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 709
diff changeset
806 }
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
807 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
808 }
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
809
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
810 // Append the official fixing interpolated to the calculation steps
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
811 //
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
812 // There was some confusion how to implement this. see flys/issue1620
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
813 // for details.
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
814 for (WQKms wqkms: officalFixings) {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
815 // To add some spaces here or to add them in the writer,..
7615
edb323a4c286 (issue1620) join column names with two empty spaces
Andre Heinecke <aheinecke@intevation.de>
parents: 7614
diff changeset
816 writer.addColumn(getDesc(wqkms, true));
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
817
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
818 // Get all lines from the calculation
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
819 Map <Double, WstLine> calcLines = writer.getLines();
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
820
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
821 // All KM values where we have a point for
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
822 TDoubleArrayList officialKms = wqkms.allKms();
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
823
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
824 for (Map.Entry<Double, WstLine> entry : calcLines.entrySet()) {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
825 // Bad for perfomance but the user can wait a bit for WST
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
826 // so lets not spend time optimizing too much,.. *hides*
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
827 double km = entry.getKey().doubleValue();
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
828 int idx = officialKms.indexOf(km);
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
829 if (idx != -1) {
7614
3e3a4f44423a (issue1620) Print the real official Q value instead of the first
Andre Heinecke <aheinecke@intevation.de>
parents: 7604
diff changeset
830 entry.getValue().add(wqkms.getW(idx), wqkms.getQ(idx));
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
831 }
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
832 }
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
833
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
834 /* Variant: Interpolate the values
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
835 // Now get the lines for the of the calculation
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
836 Map <Double, WstLine> calcLines = writer.getLines();
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
837
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
838 // Create an interpolater for the official KM -> W relation
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
839 UnivariateRealFunction wFunc = new LinearInterpolator(
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
840 ).interpolate(wqkms.allKms().toNativeArray(),
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
841 wqkms.allWs().toNativeArray());
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
842
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
843 // Now for each calculated point add the interpolated official
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
844 for (Map.Entry<Double, WstLine> entry : calcLines.entrySet()) {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
845 try {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
846 double wVal = wFunc.value(entry.getKey().doubleValue());
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
847 // Matching Q's are guranteed otherwise we would
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
848 // not have an official line
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
849 entry.getValue().add(wVal, entry.getValue().getQ(0));
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
850 }
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
851 catch (FunctionEvaluationException aode) {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
852 // should not happen
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
853 log.error("spline interpolation failed", aode);
7604
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
854 // entry.getValue().add(Double.NaN, entry.getValue().getQ(0));
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
855 }
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
856 }*/
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
857
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
858 /* Variant: Add all official fixings
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
859 // Warning the WSTWriter does not handle this properly
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
860 // as it writes the points for which only a calculation
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
861 // exists in the first column
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
862 int size = wqkms.size();
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
863 result = new double[4];
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
864 for (int i = 0; i < size; i++) {
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
865 result = wqkms.get(i, result);
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
866 writer.add(result);
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
867 }
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
868 */
05549a84ee83 (issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents: 7254
diff changeset
869 }
446
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
870 }
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
871
c0bec245f608 Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 445
diff changeset
872
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
873 /**
6576
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6101
diff changeset
874 * Register a new column at <i>writer</i>. The name /
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
875 * title of the column depends on the Q or W value of <i>wqkms</i>. If a Q
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
876 * was selected and the Q fits to a named main value, the title is set to
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
877 * the named main value. Otherwise, the name returned by
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
878 * <i>WQKms.getName()</i> is set.
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
879 *
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
880 * @param writer The WstWriter.
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
881 * @param wqkms The new WST column.
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
882 */
450
c8bb38115290 Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 447
diff changeset
883 protected void addWSTColumn(WstWriter writer, WQKms wqkms) {
4836
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
884 if (wqkms instanceof ConstantWQKms) {
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
885 return;
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
886 }
2038
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
887 if (master instanceof WINFOArtifact) {
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
888 writer.addColumn(getColumnTitle((WINFOArtifact) master, wqkms));
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
889 }
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
890 else {
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
891 writer.addColumn(wqkms.getName());
f73036b991e2 Bugfix: repaired broken named values in exports - the last solution had bad side effects.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2035
diff changeset
892 }
450
c8bb38115290 Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 447
diff changeset
893 }
c8bb38115290 Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 447
diff changeset
894
c8bb38115290 Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 447
diff changeset
895
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
896 @Override
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
897 protected void writePDF(OutputStream out) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
898 log.debug("write PDF");
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
899 WKmsJRDataSource source = createJRData();
2185
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
900
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
901 String jasperFile = Resources.getMsg(
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
902 context.getMeta(),
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
903 JASPER_FILE,
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
904 "/jasper/waterlevel_en.jasper");
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
905 String confPath = Config.getConfigDirectory().toString();
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
906
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
907
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
908 Map parameters = new HashMap();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
909 parameters.put("ReportTitle", "Exported Data");
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
910 try {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
911 JasperPrint print = JasperFillManager.fillReport(
2185
a9a8df1473fd Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2182
diff changeset
912 confPath + jasperFile,
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
913 parameters,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
914 source);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
915 JasperExportManager.exportReportToPdfStream(print, out);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
916 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
917 catch(JRException je) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
918 log.warn("Error generating PDF Report!", je);
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
919 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
920 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
921
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
922 protected WKmsJRDataSource createJRData() {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
923 WKmsJRDataSource source = new WKmsJRDataSource();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
924
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
925 WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact)master);
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
926 boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
927 boolean isQ = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
928
6608
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
929 Double first = Double.NaN;
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
930 Double last = Double.NaN;
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
931
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
932 addMetaData(source);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
933 for (WQKms[] tmp: data) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
934 for (WQKms wqkms: tmp) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
935 addWKmsData(wqkms, atGauge, isQ, source);
6608
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
936 double[] firstLast = wqkms.getFirstLastKM();
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
937 if (first.isNaN()) {
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
938 /* Initialize */
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
939 first = firstLast[0];
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
940 last = firstLast[1];
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
941 }
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
942 if (firstLast[0] > firstLast[1]) {
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
943 /* Calculating upstream we assert that it is
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
944 * impossible that the direction changes during this
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
945 * loop */
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
946 first = Math.max(first, firstLast[0]);
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
947 last = Math.min(last, firstLast[1]);
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
948 } else if (firstLast[0] < firstLast[1]) {
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
949 first = Math.min(first, firstLast[0]);
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
950 last = Math.max(last, firstLast[1]);
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
951 } else {
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
952 first = last = firstLast[0];
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
953 }
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
954 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
955 }
6608
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
956
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
957 /* Append the official fixing at the bottom */
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
958 for (WQKms wqkms: officalFixings) {
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
959 addWKmsData(filterWQKms(wqkms, first, last), atGauge, isQ, source);
3d23f606512f Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents: 6607
diff changeset
960 }
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
961 return source;
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
962 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
963
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
964 protected void addMetaData(WKmsJRDataSource source) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
965 CallMeta meta = context.getMeta();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
966
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
967 D4EArtifact flys = (D4EArtifact) master;
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
968
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
969 source.addMetaData ("river", RiverUtils.getRivername(flys));
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
970
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
971 Locale locale = Resources.getLocale(meta);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
972 DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT, locale);
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
973 NumberFormat kmf = getKmFormatter();
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
974
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
975 source.addMetaData("date", df.format(new Date()));
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
976
6101
a0078e5e3b39 Removed unused context from RangeAccess and subclasses leading to some dead code removal.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6074
diff changeset
977 RangeAccess rangeAccess = new RangeAccess(flys);
4859
e31231d0a720 WaterlevelExporter: Updated to use RangeAccess instead of FLYSUtils.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 4836
diff changeset
978 double[] kms = rangeAccess.getKmRange();
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
979 source.addMetaData("range",
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
980 kmf.format(kms[0]) + " - " + kmf.format(kms[kms.length-1]));
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
981
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
982 source.addMetaData("gauge", RiverUtils.getGaugename(flys));
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
983
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
984 source.addMetaData("calculation", Resources.getMsg(
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
985 locale,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
986 PDF_HEADER_MODE,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
987 "Waterlevel"));
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
988 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
989
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
990 protected void addWKmsData(
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
991 WQKms wqkms,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
992 boolean atGauge,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
993 boolean isQ,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
994 WKmsJRDataSource source)
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
995 {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
996 log.debug("WaterlevelExporter.addWKmsData");
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
997
4836
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
998 // Skip constant data.
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
999 if (wqkms instanceof ConstantWQKms) {
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
1000 return;
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
1001 }
01e82da3f919 Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4433
diff changeset
1002
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1003 NumberFormat kmf = getKmFormatter();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1004 NumberFormat wf = getWFormatter();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1005 NumberFormat qf = getQFormatter();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1006
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1007 int size = wqkms.size();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1008 double[] result = new double[3];
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1009
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
1010 D4EArtifact flys = (D4EArtifact) master;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
1011 Gauge gauge = RiverUtils.getGauge(flys);
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1012 String gaugeName = gauge.getName();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1013 String desc = "";
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1014 String notinrange = msg(
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1015 CSV_NOT_IN_GAUGE_RANGE,
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1016 DEFAULT_CSV_NOT_IN_GAUGE_RANGE);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1017
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1018 double a = gauge.getRange().getA().doubleValue();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1019 double b = gauge.getRange().getB().doubleValue();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1020
6606
b4fcc9308d00 Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents: 6605
diff changeset
1021 desc = getDesc(wqkms, isQ);
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1022 long startTime = System.currentTimeMillis();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1023
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1024 for (int i = 0; i < size; i ++) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1025 result = wqkms.get(i, result);
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1026
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1027 if (atGauge) {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1028 source.addData(new String[] {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1029 kmf.format(result[2]),
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1030 wf.format(result[0]),
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
1031 qf.format(RiverUtils.roundQ(result[1])),
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1032 desc,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
1033 RiverUtils.getLocationDescription(flys, result[2]),
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1034 result[2] >= a && result[2] <= b
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1035 ? gaugeName
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1036 : notinrange
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1037 });
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1038 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1039 else {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1040 source.addData(new String[] {
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1041 kmf.format(result[2]),
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1042 wf.format(result[0]),
6941
d322da01d862 (issue1451) Round Q's in the way it is done for AT's and localize KM
Andre Heinecke <aheinecke@intevation.de>
parents: 6634
diff changeset
1043 qf.format(RiverUtils.roundQ(result[1])),
2764
f8a1a8af338e Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2612
diff changeset
1044 desc,
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
1045 RiverUtils.getLocationDescription(flys, result[2]),
2764
f8a1a8af338e Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2612
diff changeset
1046 result[2] >= a && result[2] <= b
f8a1a8af338e Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2612
diff changeset
1047 ? gaugeName
f8a1a8af338e Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2612
diff changeset
1048 : notinrange
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1049 });
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1050 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1051 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1052
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1053 long stopTime = System.currentTimeMillis();
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1054
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
1055 if (log.isDebugEnabled()) {
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7639
diff changeset
1056 log.debug("Writing PDF data took " +
2176
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1057 (float)(stopTime-startTime)/1000f + " secs.");
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1058 }
65dac9cf6ff5 Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2144
diff changeset
1059 }
389
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
1060 }
69d05357c177 Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
1061 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org