Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java @ 7620:22b9d2dfb4d2
Use IsOfficialAccess instead of direct property in WaterlevelExporter.
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Fri, 29 Nov 2013 12:18:16 +0100 |
parents | edb323a4c286 |
children | 11bc2d6a2059 |
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 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
30 import org.apache.commons.math.FunctionEvaluationException; |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
31 import org.apache.commons.math.analysis.UnivariateRealFunction; |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
32 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
33 import org.apache.commons.math.analysis.interpolation.LinearInterpolator; |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
34 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
35 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
|
36 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
37 import net.sf.jasperreports.engine.JasperExportManager; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
38 import net.sf.jasperreports.engine.JasperFillManager; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
39 import net.sf.jasperreports.engine.JasperPrint; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
40 import net.sf.jasperreports.engine.JRException; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
41 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
42 import org.dive4elements.artifacts.Artifact; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
43 import org.dive4elements.artifacts.CallMeta; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
44 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
|
45 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
46 import org.dive4elements.river.model.Gauge; |
706
ddd8b37d5cd3
Removed dead code.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
701
diff
changeset
|
47 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
48 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
|
49 import org.dive4elements.river.artifacts.access.IsOfficialAccess; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
50 import org.dive4elements.river.artifacts.access.RangeAccess; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
51 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
|
52 import org.dive4elements.river.artifacts.D4EArtifact; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
53 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
|
54 import org.dive4elements.river.artifacts.StaticWQKmsArtifact; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
55 import org.dive4elements.river.artifacts.model.CalculationResult; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
56 import org.dive4elements.river.artifacts.model.Segment; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
57 import org.dive4elements.river.artifacts.model.WQCKms; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
58 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
|
59 import org.dive4elements.river.artifacts.model.WstLine; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
60 import org.dive4elements.river.artifacts.model.WKmsJRDataSource; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
61 import org.dive4elements.river.artifacts.model.WQKmsResult; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
62 import org.dive4elements.river.artifacts.resources.Resources; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
63 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
64 import org.dive4elements.river.utils.RiverUtils; |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
65 import org.dive4elements.river.utils.RiverUtils.WQ_MODE; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
66 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
|
67 |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
68 /** |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
69 * 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
|
70 * 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
|
71 * |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
72 * @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
|
73 */ |
391
5d6988836f01
Added an exporter to export the computed data of a duration curve.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
389
diff
changeset
|
74 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
|
75 |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
76 /** The logger used in this exporter.*/ |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
77 private static Logger logger = Logger.getLogger(WaterlevelExporter.class); |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
78 |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
79 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
|
80 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
81 /* 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
|
82 public static final String STATICWQKMSNAME = "staticwqkms"; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
83 |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
84 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
|
85 "export.waterlevel.csv.header.km"; |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
86 |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
87 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
|
88 "export.waterlevel.csv.header.w"; |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
89 |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
90 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
|
91 "export.waterlevel.csv.header.q"; |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
92 |
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
|
93 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
|
94 "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
|
95 |
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
|
96 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
|
97 "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
|
98 |
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
|
99 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
|
100 "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
|
101 |
97a25b54eea3
Part 1 of #125: added a description for a location to the WaterlevelExport.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2045
diff
changeset
|
102 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
|
103 "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
|
104 |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
105 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
|
106 "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
|
107 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
108 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
|
109 "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
|
110 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
111 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
|
112 "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
|
113 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
114 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
|
115 "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
|
116 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
117 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
|
118 "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
|
119 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
120 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
|
121 "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
|
122 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
123 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
|
124 "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
|
125 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
126 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
|
127 "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
|
128 |
2066
2b6a0de47379
Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2065
diff
changeset
|
129 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
|
130 "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
|
131 |
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
|
132 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
|
133 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
|
134 |
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_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
|
136 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
|
137 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
|
138 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
|
139 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
|
140 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
|
141 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
|
142 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
|
143 "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
|
144 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
145 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
|
146 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
|
147 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
148 /** 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
|
149 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
|
150 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
151 /** 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
|
152 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
|
153 |
7077
0a337f0005c2
Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6941
diff
changeset
|
154 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
|
155 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
|
156 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
157 |
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 @Override |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
159 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
|
160 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
|
161 { |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
162 logger.debug("WaterlevelExporter.generate"); |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
163 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
164 /* 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
|
165 * 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
|
166 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
167 officalFixings = new ArrayList<WQKms>(); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
168 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
169 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
|
170 if (art instanceof StaticWQKmsArtifact) { |
7620
22b9d2dfb4d2
Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7615
diff
changeset
|
171 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
|
172 StaticWQKmsArtifact sart = (StaticWQKmsArtifact) art; |
7620
22b9d2dfb4d2
Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7615
diff
changeset
|
173 if (!access.isOfficial()) { |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
174 continue; |
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 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
177 /* 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
|
178 WQKms toAdd = sart.getWQKms(); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
179 String newName = toAdd.getName(); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
180 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
181 boolean exists = false; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
182 for (WQKms wqkm: officalFixings) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
183 /* 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
|
184 artifacts/outs so let's deduplicate */ |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
185 if (wqkm.getName().equals(newName)) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
186 exists = true; |
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 if (!exists) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
190 officalFixings.add(toAdd); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
191 logger.debug("Adding additional offical fixing: " + newName); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
192 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
193 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
194 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
195 |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
196 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
|
197 generateCSV(); |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
198 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
199 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
|
200 generateWST(); |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
201 } |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
202 else if (facet != null && facet.equals(AbstractExporter.FACET_PDF)) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
203 generatePDF(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
204 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
205 else { |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
206 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
|
207 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
208 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
209 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
210 |
701
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
211 @Override |
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
212 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
|
213 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
|
214 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
|
215 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
|
216 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
|
217 } |
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
|
218 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
|
219 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
|
220 } |
701
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
221 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
222 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
223 |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
224 |
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
|
225 /** |
6576 | 226 * 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
|
227 * 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
|
228 * 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
|
229 * 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
|
230 * 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
|
231 * |
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 * @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
|
233 * @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
|
234 */ |
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
|
235 protected String getColumnTitle(WINFOArtifact winfo, WQKms wqkms) { |
5131
42bae65c116b
WaterlevelExporter: Fix log output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5112
diff
changeset
|
236 logger.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
|
237 |
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
|
238 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
|
239 |
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
|
240 logger.debug("Name of WQKms = '" + 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
|
241 |
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
|
242 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
|
243 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
|
244 } |
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
|
245 |
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
|
246 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
|
247 |
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 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
|
249 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
|
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 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
|
252 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
|
253 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
254 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
|
255 |
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
|
256 if (nmv != null && nmv.length() > 0) { |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
257 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
|
258 nmv += "=" + String.valueOf(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
|
259 logger.debug("Set named main value '" + nmv + "'"); |
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 |
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
|
261 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
|
262 } |
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
|
263 } |
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
|
264 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
|
265 // 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
|
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 } |
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
|
268 |
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
|
269 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
|
270 } |
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
|
271 |
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
|
272 |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
273 protected String getCSVRowTitle(WINFOArtifact winfo, WQKms wqkms) { |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
274 logger.debug("WaterlevelExporter.prepareNamedValue"); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
275 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
276 String name = wqkms.getName(); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
277 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
278 logger.debug("Name of WQKms = '" + name + "'"); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
279 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
280 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
|
281 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
282 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
|
283 return localizeWQKms(winfo, wqkms); |
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 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
286 Double v = wqkms.getRawValue(); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
287 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
288 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
|
289 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
290 if (nmv != null && nmv.length() > 0) { |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
291 nmv = RiverUtils.stripNamedMainValue(nmv); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
292 logger.debug("Set named main value '" + nmv + "'"); |
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 return nmv; |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
295 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
296 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
297 return localizeWQKms(winfo, wqkms); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
298 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
299 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
300 |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
301 /** |
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
302 * 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
|
303 * format. |
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
304 */ |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
305 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
|
306 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
|
307 Double rawValue = wqkms.getRawValue(); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
308 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
309 if (rawValue == null) { |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
310 return wqkms.getName(); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
311 } |
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 NumberFormat nf = Formatter.getRawFormatter(context); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
314 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
315 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
|
316 return "W=" + nf.format(rawValue); |
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 else { |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
319 return "Q=" + nf.format(rawValue); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
320 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
321 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
322 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
323 |
701
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
324 @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
|
325 protected void writeCSVData(CSVWriter writer) { |
5d6988836f01
Added an exporter to export the computed data of a duration curve.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
389
diff
changeset
|
326 logger.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
|
327 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
328 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
|
329 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
|
330 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
|
331 RiverUtils.WQ_INPUT input |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
332 = 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
|
333 |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
334 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
|
335 writeCSVHeader(writer, atGauge, isQ); |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
336 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
337 Double first = Double.NaN; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
338 Double last = Double.NaN; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
339 |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
340 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
|
341 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
|
342 wQKms2CSV(writer, wqkms, atGauge, isQ); |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
343 double[] firstLast = wqkms.getFirstLastKM(); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
344 if (first.isNaN()) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
345 /* Initialize */ |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
346 first = firstLast[0]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
347 last = firstLast[1]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
348 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
349 if (firstLast[0] > firstLast[1]) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
350 /* 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
|
351 * 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
|
352 * loop */ |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
353 first = Math.max(first, firstLast[0]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
354 last = Math.min(last, firstLast[1]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
355 } else if (firstLast[0] < firstLast[1]) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
356 first = Math.min(first, firstLast[0]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
357 last = Math.max(last, firstLast[1]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
358 } else { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
359 first = last = firstLast[0]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
360 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
361 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
362 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
363 /* 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
|
364 for (WQKms wqkms: officalFixings) { |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
365 wQKms2CSV(writer, filterWQKms(wqkms, first, last), atGauge, isQ); |
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 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
368 |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
369 |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
370 /** Filter a wqkms object to a distance. |
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 * To handle upstream / downstream and to limit |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
373 * the officialFixings to the calculation distance |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
374 * 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
|
375 * with the relevant data. |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
376 * |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
377 * @param wqkms: The WQKms Object to filter |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
378 * @param first: The fist kilometer of the range |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
379 * @param last: The last kilometer of the range |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
380 * |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
381 * @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
|
382 */ |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
383 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
|
384 if (first.isNaN() || last.isNaN()) { |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
385 logger.warn("Filtering official fixing without valid first/last."); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
386 return wqkms; |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
387 } |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
388 int firstIdx = first > last ? wqkms.size() - 1 : 0; |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
389 int lastIdx = first > last ? 0 : wqkms.size() -1; |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
390 WQKms filtered = new WQKms (wqkms.size()); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
391 filtered.setReferenceSystem(wqkms.getReferenceSystem()); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
392 filtered.setName(wqkms.getName()); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
393 double [] dp = new double [3]; |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
394 |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
395 if (first > last) { |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
396 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
|
397 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
|
398 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
|
399 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
|
400 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
401 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
402 } 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
|
403 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
|
404 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
|
405 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
|
406 filtered.add(dp[0], dp[1], dp[2]); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
407 } |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
408 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
409 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
410 return filtered; |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
411 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
412 |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
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 protected void writeCSVMeta(CSVWriter writer) { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
415 logger.info("WaterlevelExporter.writeCSVMeta"); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
416 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
417 // 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
|
418 |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
419 CallMeta meta = context.getMeta(); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
420 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
421 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
|
422 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
423 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
424 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
425 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
426 CSV_META_RESULT, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
427 CSV_META_RESULT, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
428 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
|
429 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
430 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
431 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
|
432 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
|
433 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
434 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
435 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
436 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
437 CSV_META_CREATION, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
438 CSV_META_CREATION, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
439 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
|
440 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
441 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
442 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
443 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
444 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
445 CSV_META_CALCULATIONBASE, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
446 CSV_META_CALCULATIONBASE, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
447 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
|
448 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
449 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
450 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
451 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
452 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
453 CSV_META_RIVER, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
454 CSV_META_RIVER, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
455 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
|
456 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
457 |
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
|
458 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
|
459 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
|
460 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
461 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
462 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
463 CSV_META_RANGE, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
464 CSV_META_RANGE, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
465 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
|
466 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
467 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
468 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
469 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
470 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
471 CSV_META_GAUGE, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
472 CSV_META_GAUGE, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
473 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
|
474 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
475 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
476 RiverUtils.WQ_MODE wq = RiverUtils.getWQMode(flys); |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
477 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
|
478 double[] qs = RiverUtils.getQs(flys); |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
479 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
|
480 |
2423
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
481 String data = ""; |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
482 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
483 if ((input == RiverUtils.WQ_INPUT.ADAPTED || |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
484 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
|
485 qs != null && qs.length > 0) |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
486 { |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
487 data = String.valueOf(qs[0]); |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
488 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
|
489 } |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
490 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
|
491 data = String.valueOf(qs[0]); |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
492 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
|
493 data += ", " + String.valueOf(qs[i]); |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
494 } |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
495 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
496 else { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
497 logger.warn("Could not determine Q range!"); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
498 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
499 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
500 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
501 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
502 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
503 CSV_META_Q, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
504 CSV_META_Q, |
2423
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
505 new Object[] {data}) |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
506 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
507 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
508 else { |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
509 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
|
510 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
511 String lower = ""; |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
512 String upper = ""; |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
513 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
514 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
|
515 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
|
516 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
|
517 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
518 else { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
519 logger.warn("Could not determine W range!"); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
520 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
521 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
522 writer.writeNext(new String[] { |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
523 Resources.getMsg( |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
524 meta, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
525 CSV_META_W, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
526 CSV_META_W, |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
527 new Object[] { lower, upper }) |
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 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
530 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
531 writer.writeNext(new String[] { "" }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
532 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
533 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
534 |
4979
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
535 /** |
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
536 * 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
|
537 * gauge or at a location. |
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
538 */ |
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
|
539 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
|
540 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
|
541 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
|
542 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
|
543 ) { |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
544 logger.info("WaterlevelExporter.writeCSVHeader"); |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
545 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
546 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
|
547 |
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
|
548 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
|
549 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
|
550 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
|
551 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
|
552 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
|
553 (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
|
554 ? 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
|
555 : 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
|
556 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
|
557 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
|
558 }); |
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
|
559 } |
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 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
|
561 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
|
562 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
|
563 // 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
|
564 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
|
565 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
|
566 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
|
567 }); |
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
|
568 } |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
569 } |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
570 |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
571 |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
572 /** 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
|
573 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
|
574 for (Gauge gauge: gauges) { |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
575 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
|
576 return gauge; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
577 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
578 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
579 return null; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
580 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
581 |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
582 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
|
583 for (Segment segment: segments) { |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
584 if (segment.inside(km)) { |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
585 return segment; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
586 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
587 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
588 return null; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
589 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
590 |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
591 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
592 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
|
593 NumberFormat kmf = getKmFormatter(); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
594 NumberFormat wf = getWFormatter(); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
595 NumberFormat qf = getQFormatter(); |
6607 | 596 writer.writeNext(new String[] { |
597 kmf.format(wqkm[2]), | |
598 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
|
599 qf.format(RiverUtils.roundQ(wqkm[1])), |
6607 | 600 RiverUtils.getLocationDescription(flys, wqkm[2]) |
601 }); | |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
602 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
603 |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
604 /** 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
|
605 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
|
606 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
|
607 NumberFormat kmf = getKmFormatter(); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
608 NumberFormat wf = getWFormatter(); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
609 NumberFormat qf = getQFormatter(); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
610 |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
611 writer.writeNext(new String[] { |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
612 kmf.format(wqkm[2]), |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
613 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
|
614 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
|
615 wOrQDesc, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
616 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
|
617 gaugeName |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
618 }); |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
619 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
620 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
621 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
|
622 { |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
623 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
|
624 String colDesc = ""; |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
625 |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
626 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
|
627 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
|
628 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
629 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
|
630 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
|
631 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
|
632 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
|
633 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
634 |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
635 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
|
636 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
|
637 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
|
638 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
|
639 // 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
|
640 if (colDesc == null) { |
6634
b1e66ea7fc2b
Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents:
6610
diff
changeset
|
641 Double value = RiverUtils.getValueFromWQ(wqkms); |
b1e66ea7fc2b
Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents:
6610
diff
changeset
|
642 colDesc = (value != null) ? |
b1e66ea7fc2b
Fix Waterlevel description for issue1404
Andre Heinecke <aheinecke@intevation.de>
parents:
6610
diff
changeset
|
643 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
|
644 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
645 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
646 } |
6610
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
647 if (colDesc != null) { |
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
648 /* 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
|
649 * 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
|
650 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
|
651 } |
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
652 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
653 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
|
654 } |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
655 |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
656 /** |
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
657 * 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
|
658 */ |
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 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
|
660 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
|
661 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
|
662 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
|
663 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
|
664 ) { |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
665 logger.debug("WaterlevelExporter.wQKms2CSV"); |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
666 |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
667 // Skip constant data. |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
668 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
669 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
670 } |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
671 |
418
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
672 NumberFormat kmf = getKmFormatter(); |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
673 NumberFormat wf = getWFormatter(); |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
674 NumberFormat qf = getQFormatter(); |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
675 |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
676 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
|
677 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
|
678 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
679 D4EArtifact flys = (D4EArtifact) master; |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
680 List<Gauge> gauges = RiverUtils.getGauges(flys); |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
681 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
|
682 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
|
683 String desc = ""; |
2b6a0de47379
Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2065
diff
changeset
|
684 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
|
685 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
|
686 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
|
687 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
|
688 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
|
689 |
2b6a0de47379
Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2065
diff
changeset
|
690 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
|
691 double b = gauge.getRange().getB().doubleValue(); |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
692 long startTime = System.currentTimeMillis(); |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
693 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
694 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
|
695 |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
696 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
|
697 // 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
|
698 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
|
699 segments = fixAccess.getSegments(); |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
700 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
|
701 isFixRealize = true; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
702 } |
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
|
703 } |
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
|
704 |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
705 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
|
706 |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
707 // 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
|
708 // is a good time saving heuristic. |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
709 Segment lastSegment = null; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
710 Gauge lastGauge = null; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
711 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
712 NumberFormat nf = |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
713 Formatter.getFormatter(context.getMeta(), 0, 0); |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
714 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
715 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
|
716 result = wqkms.get(i, result); |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
717 double km = result[2]; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
718 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
719 if (segments != null) { |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
720 Segment found = lastSegment != null |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
721 && lastSegment.inside(km) |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
722 ? lastSegment |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
723 : findSegment(km, segments); |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
724 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
725 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
|
726 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
|
727 } |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
728 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
|
729 } |
15e856a64cdd
Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4979
diff
changeset
|
730 |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
731 String gaugeN; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
732 if (isFixRealize) { |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
733 Gauge found = lastGauge != null |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
734 && lastGauge.getRange().contains(km) |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
735 ? lastGauge |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
736 : findGauge(km, gauges); |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
737 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
738 gaugeN = found != null ? found.getName() : notinrange; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
739 lastGauge = found; |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
740 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
741 else { |
4979
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
742 // TODO issue1114: Take correct gauge |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
743 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
|
744 ? gaugeName |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
745 : notinrange; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
746 } |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
747 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
|
748 } |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
749 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
750 else { // Not at gauge. |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
751 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
|
752 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
|
753 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
|
754 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
755 } |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
756 |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
757 long stopTime = System.currentTimeMillis(); |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
758 |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
759 if (logger.isDebugEnabled()) { |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
760 logger.debug("Writing CSV took " + |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
761 (float)(stopTime-startTime)/1000f + " secs."); |
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
762 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
763 } |
418
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
764 |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
765 |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
766 /** |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
767 * 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
|
768 */ |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
769 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
|
770 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
|
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 logger.info("WaterlevelExporter.generateWST"); |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
773 |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
774 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
|
775 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
|
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 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
|
778 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
779 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
|
780 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
781 |
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 protected void writeWSTData(WstWriter writer) { |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
784 logger.debug("WaterlevelExporter.writeWSTData"); |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
785 |
749
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
786 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
|
787 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
788 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
|
789 for (WQKms wqkms: tmp) { |
5105
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
790 if (wqkms instanceof ConstantWQKms) { |
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
791 continue; |
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
792 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
793 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
|
794 |
450
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
795 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
|
796 |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
797 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
|
798 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
|
799 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
800 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
|
801 } |
749
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
802 |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
803 if (wqkms instanceof WQCKms) { |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
804 addWSTColumn(writer, wqkms); |
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 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
|
807 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
|
808 |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
809 writer.addCorrected(result); |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
810 } |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
811 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
812 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
813 } |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
814 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
815 // 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
|
816 // |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
817 // 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
|
818 // for details. |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
819 for (WQKms wqkms: officalFixings) { |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
820 // 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
|
821 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
|
822 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
823 // 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
|
824 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
|
825 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
826 // 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
|
827 TDoubleArrayList officialKms = wqkms.allKms(); |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
828 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
829 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
|
830 // 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
|
831 // 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
|
832 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
|
833 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
|
834 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
|
835 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
|
836 } |
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 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
839 /* Variant: Interpolate the values |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
840 // 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
|
841 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
|
842 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
843 // 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
|
844 UnivariateRealFunction wFunc = new LinearInterpolator( |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
845 ).interpolate(wqkms.allKms().toNativeArray(), |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
846 wqkms.allWs().toNativeArray()); |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
847 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
848 // 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
|
849 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
|
850 try { |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
851 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
|
852 // 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
|
853 // 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
|
854 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
|
855 } |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
856 catch (FunctionEvaluationException aode) { |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
857 // should not happen |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
858 logger.error("spline interpolation failed", aode); |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
859 // 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
|
860 } |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
861 }*/ |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
862 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
863 /* 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
|
864 // 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
|
865 // 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
|
866 // 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
|
867 int size = wqkms.size(); |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
868 result = new double[4]; |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
869 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
|
870 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
|
871 writer.add(result); |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
872 } |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
873 */ |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
874 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
875 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
876 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
877 |
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
|
878 /** |
6576 | 879 * 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
|
880 * 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
|
881 * 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
|
882 * 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
|
883 * <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
|
884 * |
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
|
885 * @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
|
886 * @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
|
887 */ |
450
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
888 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
|
889 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
890 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
891 } |
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
|
892 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
|
893 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
|
894 } |
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
|
895 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
|
896 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
|
897 } |
450
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
898 } |
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
899 |
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
900 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
901 @Override |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
902 protected void writePDF(OutputStream out) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
903 logger.debug("write PDF"); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
904 WKmsJRDataSource source = createJRData(); |
2185
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
905 |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
906 String jasperFile = Resources.getMsg( |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
907 context.getMeta(), |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
908 JASPER_FILE, |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
909 "/jasper/waterlevel_en.jasper"); |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
910 String confPath = Config.getConfigDirectory().toString(); |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
911 |
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
912 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
913 Map parameters = new HashMap(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
914 parameters.put("ReportTitle", "Exported Data"); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
915 try { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
916 JasperPrint print = JasperFillManager.fillReport( |
2185
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
917 confPath + jasperFile, |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
918 parameters, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
919 source); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
920 JasperExportManager.exportReportToPdfStream(print, out); |
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 catch(JRException je) { |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
923 logger.warn("Error generating PDF Report!", je); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
924 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
925 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
926 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
927 protected WKmsJRDataSource createJRData() { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
928 WKmsJRDataSource source = new WKmsJRDataSource(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
929 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
930 WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact)master); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
931 boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
932 boolean isQ = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
933 |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
934 Double first = Double.NaN; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
935 Double last = Double.NaN; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
936 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
937 addMetaData(source); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
938 for (WQKms[] tmp: data) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
939 for (WQKms wqkms: tmp) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
940 addWKmsData(wqkms, atGauge, isQ, source); |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
941 double[] firstLast = wqkms.getFirstLastKM(); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
942 if (first.isNaN()) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
943 /* Initialize */ |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
944 first = firstLast[0]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
945 last = firstLast[1]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
946 } |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
947 if (firstLast[0] > firstLast[1]) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
948 /* Calculating upstream we assert that it is |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
949 * impossible that the direction changes during this |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
950 * loop */ |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
951 first = Math.max(first, firstLast[0]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
952 last = Math.min(last, firstLast[1]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
953 } else if (firstLast[0] < firstLast[1]) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
954 first = Math.min(first, firstLast[0]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
955 last = Math.max(last, firstLast[1]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
956 } else { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
957 first = last = firstLast[0]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
958 } |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
959 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
960 } |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
961 |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
962 /* Append the official fixing at the bottom */ |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
963 for (WQKms wqkms: officalFixings) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
964 addWKmsData(filterWQKms(wqkms, first, last), atGauge, isQ, source); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
965 } |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
966 return source; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
967 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
968 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
969 protected void addMetaData(WKmsJRDataSource source) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
970 CallMeta meta = context.getMeta(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
971 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
972 D4EArtifact flys = (D4EArtifact) master; |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
973 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
974 source.addMetaData ("river", RiverUtils.getRivername(flys)); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
975 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
976 Locale locale = Resources.getLocale(meta); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
977 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
|
978 NumberFormat kmf = getKmFormatter(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
979 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
980 source.addMetaData("date", df.format(new Date())); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
981 |
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
|
982 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
|
983 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
|
984 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
|
985 kmf.format(kms[0]) + " - " + kmf.format(kms[kms.length-1])); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
986 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
987 source.addMetaData("gauge", RiverUtils.getGaugename(flys)); |
2176
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 source.addMetaData("calculation", Resources.getMsg( |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
990 locale, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
991 PDF_HEADER_MODE, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
992 "Waterlevel")); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
993 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
994 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
995 protected void addWKmsData( |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
996 WQKms wqkms, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
997 boolean atGauge, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
998 boolean isQ, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
999 WKmsJRDataSource source) |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1000 { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1001 logger.debug("WaterlevelExporter.addWKmsData"); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1002 |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1003 // Skip constant data. |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1004 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1005 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1006 } |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1007 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1008 NumberFormat kmf = getKmFormatter(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1009 NumberFormat wf = getWFormatter(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1010 NumberFormat qf = getQFormatter(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1011 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1012 int size = wqkms.size(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1013 double[] result = new double[3]; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1014 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
1015 D4EArtifact flys = (D4EArtifact) master; |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
1016 Gauge gauge = RiverUtils.getGauge(flys); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1017 String gaugeName = gauge.getName(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1018 String desc = ""; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1019 String notinrange = msg( |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1020 CSV_NOT_IN_GAUGE_RANGE, |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1021 DEFAULT_CSV_NOT_IN_GAUGE_RANGE); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1022 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1023 double a = gauge.getRange().getA().doubleValue(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1024 double b = gauge.getRange().getB().doubleValue(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1025 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
1026 desc = getDesc(wqkms, isQ); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1027 long startTime = System.currentTimeMillis(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1028 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1029 for (int i = 0; i < size; i ++) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1030 result = wqkms.get(i, result); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1031 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1032 if (atGauge) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1033 source.addData(new String[] { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1034 kmf.format(result[2]), |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1035 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
|
1036 qf.format(RiverUtils.roundQ(result[1])), |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1037 desc, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
1038 RiverUtils.getLocationDescription(flys, result[2]), |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1039 result[2] >= a && result[2] <= b |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1040 ? gaugeName |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1041 : notinrange |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1042 }); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1043 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1044 else { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1045 source.addData(new String[] { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1046 kmf.format(result[2]), |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1047 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
|
1048 qf.format(RiverUtils.roundQ(result[1])), |
2764
f8a1a8af338e
Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2612
diff
changeset
|
1049 desc, |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
1050 RiverUtils.getLocationDescription(flys, result[2]), |
2764
f8a1a8af338e
Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2612
diff
changeset
|
1051 result[2] >= a && result[2] <= b |
f8a1a8af338e
Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2612
diff
changeset
|
1052 ? gaugeName |
f8a1a8af338e
Issue 667.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2612
diff
changeset
|
1053 : notinrange |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1054 }); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1055 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1056 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1057 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1058 long stopTime = System.currentTimeMillis(); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1059 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1060 if (logger.isDebugEnabled()) { |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1061 logger.debug("Writing PDF data took " + |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1062 (float)(stopTime-startTime)/1000f + " secs."); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1063 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1064 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
1065 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
1066 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 : |