Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/WaterlevelExporter.java @ 9536:aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
author | mschaefer |
---|---|
date | Tue, 16 Oct 2018 16:42:22 +0200 |
parents | ce13a2f07290 |
children | fb80fc7ec610 |
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; |
9082 | 16 import java.util.Date; |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
17 import java.util.HashMap; |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
18 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
|
19 import java.util.Locale; |
9082 | 20 import java.util.Map; |
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; |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
25 import org.dive4elements.artifacts.Artifact; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
26 import org.dive4elements.artifacts.CallMeta; |
9460 | 27 import org.dive4elements.river.artifacts.AbstractFixBunduArtifact; |
9082 | 28 import org.dive4elements.river.artifacts.D4EArtifact; |
29 import org.dive4elements.river.artifacts.StaticWQKmsArtifact; | |
30 import org.dive4elements.river.artifacts.WINFOArtifact; | |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
31 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
|
32 import org.dive4elements.river.artifacts.access.IsOfficialAccess; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
33 import org.dive4elements.river.artifacts.access.RangeAccess; |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
34 import org.dive4elements.river.artifacts.common.DefaultCalculationResults; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
35 import org.dive4elements.river.artifacts.common.ExportContextPDF; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
36 import org.dive4elements.river.artifacts.common.GeneralResultType; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
37 import org.dive4elements.river.artifacts.common.JasperDesigner; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
38 import org.dive4elements.river.artifacts.common.JasperReporter; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
39 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
40 import org.dive4elements.river.artifacts.model.CalculationResult; |
9082 | 41 import org.dive4elements.river.artifacts.model.ConstantWQKms; |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
42 import org.dive4elements.river.artifacts.model.DischargeTables; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
43 import org.dive4elements.river.artifacts.model.Segment; |
9082 | 44 import org.dive4elements.river.artifacts.model.WKmsJRDataSource; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
45 import org.dive4elements.river.artifacts.model.WQCKms; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
46 import org.dive4elements.river.artifacts.model.WQKms; |
9082 | 47 import org.dive4elements.river.artifacts.model.WQKmsResult; |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
48 import org.dive4elements.river.artifacts.model.WstLine; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5587
diff
changeset
|
49 import org.dive4elements.river.artifacts.resources.Resources; |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
50 import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
51 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
52 import org.dive4elements.river.model.DischargeTable; |
9082 | 53 import org.dive4elements.river.model.Gauge; |
54 import org.dive4elements.river.utils.Formatter; | |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
55 import org.dive4elements.river.utils.RiverUtils; |
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
56 import org.dive4elements.river.utils.RiverUtils.WQ_MODE; |
9082 | 57 |
58 import au.com.bytecode.opencsv.CSVWriter; | |
59 import gnu.trove.TDoubleArrayList; | |
60 import net.sf.jasperreports.engine.JRException; | |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
61 |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
62 /** |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
63 * 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
|
64 * 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
|
65 * |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
66 * @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
|
67 */ |
391
5d6988836f01
Added an exporter to export the computed data of a duration curve.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
389
diff
changeset
|
68 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
|
69 |
9082 | 70 /** The log used in this exporter. */ |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
71 private static Logger log = Logger.getLogger(WaterlevelExporter.class); |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
72 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
73 private static final String FACET_WST = "wst"; |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
74 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
75 /* This should be the same as in the StaticWQKmsArtifact */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
76 private static final String STATICWQKMSNAME = "staticwqkms"; |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
77 |
9082 | 78 public static final String CSV_KM_HEADER = "export.waterlevel.csv.header.km"; |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
79 |
9082 | 80 public static final String CSV_W_HEADER = "export.waterlevel.csv.header.w"; |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
81 |
9312 | 82 public static final String CSV_Q_HEADER = "common.export.csv.header.q"; |
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
|
83 |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
84 /** |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
85 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
86 */ |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
87 @Deprecated |
9082 | 88 public static final String CSV_Q_DESC_HEADER = "export.waterlevel.csv.header.q.desc"; |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
89 |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
90 /** |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
91 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
92 */ |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
93 @Deprecated |
9082 | 94 public static final String CSV_W_DESC_HEADER = "export.waterlevel.csv.header.w.desc"; |
95 | |
96 public static final String CSV_LOCATION_HEADER = "export.waterlevel.csv.header.location"; | |
97 | |
98 public static final String CSV_GAUGE_HEADER = "export.waterlevel.csv.header.gauge"; | |
99 | |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
100 private static final String CSV_META_RESULT = "export.waterlevel.csv.meta.result"; |
9082 | 101 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
102 private static final String CSV_META_CREATION = "export.waterlevel.csv.meta.creation"; |
9082 | 103 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
104 private static final String CSV_META_CALCULATIONBASE = "export.waterlevel.csv.meta.calculationbase"; |
9082 | 105 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
106 private static final String CSV_META_RIVER = "export.waterlevel.csv.meta.river"; |
9082 | 107 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
108 private static final String CSV_META_RANGE = "export.waterlevel.csv.meta.range"; |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
109 |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
110 private static final String CSV_META_GAUGE = "export.waterlevel.csv.meta.gauge"; |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
111 |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
112 private static final String CSV_META_Q = "common.export.waterlevel.csv.meta.q"; |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
113 |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
114 private static final String CSV_META_W = "export.waterlevel.csv.meta.w"; |
9082 | 115 |
116 public static final String CSV_NOT_IN_GAUGE_RANGE = "export.waterlevel.csv.not.in.gauge.range"; | |
117 | |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
118 private static final Pattern NUMBERS_PATTERN = Pattern.compile("\\D*(\\d++.\\d*)\\D*"); |
9082 | 119 |
120 public static final String DEFAULT_CSV_KM_HEADER = "Fluss-Km"; | |
121 public static final String DEFAULT_CSV_W_HEADER = "W [NN + m]"; | |
122 public static final String DEFAULT_CSV_Q_HEADER = "Q [m\u00b3/s]"; | |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
123 /** |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
124 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
125 */ |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
126 @Deprecated |
9082 | 127 public static final String DEFAULT_CSV_Q_DESC_HEADER = "Bezeichnung"; |
128 /** | |
129 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. | |
130 */ | |
131 @Deprecated | |
132 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
|
133 public static final String DEFAULT_CSV_LOCATION_HEADER = "Lage"; |
9082 | 134 public static final String DEFAULT_CSV_GAUGE_HEADER = "Bezugspegel"; |
135 public static final String DEFAULT_CSV_NOT_IN_GAUGE_RANGE = "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
|
136 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
137 protected static final String PDF_HEADER_MODE = "export.waterlevel.pdf.mode"; |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
138 |
9082 | 139 /** The storage that contains all WQKms objects that are calculated. */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
140 public List<WQKms[]> data; |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
141 |
9082 | 142 /** The storage that contains official fixings if available. */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
143 public 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
|
144 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
145 private final Map<String, Double> gaugeQ_W_Map = new HashMap<>(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
146 |
7077
0a337f0005c2
Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6941
diff
changeset
|
147 public WaterlevelExporter() { |
9082 | 148 this.data = new ArrayList<>(); |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
149 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
150 |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
151 @Override |
9082 | 152 public void generate() throws IOException { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
153 log.debug("WaterlevelExporter.generate"); |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
154 |
9082 | 155 /* |
156 * Check for official fixings. They should also be included in the | |
157 * export but only the calculation result is added with addData | |
158 */ | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
159 |
9082 | 160 this.officalFixings = new ArrayList<>(); |
161 | |
162 for (final Artifact art : this.collection.getArtifactsByName(STATICWQKMSNAME, this.context)) { | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
163 if (art instanceof StaticWQKmsArtifact) { |
9082 | 164 final IsOfficialAccess access = new IsOfficialAccess((D4EArtifact) art); |
165 final StaticWQKmsArtifact sart = (StaticWQKmsArtifact) art; | |
7620
22b9d2dfb4d2
Use IsOfficialAccess instead of direct property in WaterlevelExporter.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7615
diff
changeset
|
166 if (!access.isOfficial()) { |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
167 continue; |
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 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
170 /* Check that we add the data only once */ |
9082 | 171 final WQKms toAdd = sart.getWQKms(); |
172 final String newName = toAdd.getName(); | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
173 |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
174 boolean exists = false; |
9082 | 175 for (final WQKms wqkm : this.officalFixings) { |
176 /* | |
177 * The same official fixing could be in two | |
178 * artifacts/outs so let's deduplicate | |
179 */ | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
180 if (wqkm.getName().equals(newName)) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
181 exists = true; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
182 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
183 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
184 if (!exists) { |
9082 | 185 this.officalFixings.add(toAdd); |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
186 log.debug("Adding additional offical fixing: " + newName); |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
187 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
188 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
189 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
190 |
9082 | 191 if (this.facet != null && this.facet.equals(AbstractExporter.FACET_CSV)) { |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
192 generateCSV(); |
9082 | 193 } else if (this.facet != null && this.facet.equals(FACET_WST)) { |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
194 generateWST(); |
9082 | 195 } else if (this.facet != null && this.facet.equals(AbstractExporter.FACET_PDF)) { |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
196 generatePDF(); |
9082 | 197 } else { |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
198 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
|
199 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
200 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
201 |
701
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
202 @Override |
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
203 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
|
204 if (d instanceof CalculationResult) { |
9082 | 205 d = ((CalculationResult) d).getData(); |
206 if (d instanceof WQKms[]) { | |
207 this.data.add((WQKms[]) d); | |
208 } else if (d instanceof WQKmsResult) { | |
209 this.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
|
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 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
212 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
213 |
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
|
214 /** |
6576 | 215 * 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
|
216 * 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
|
217 * 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
|
218 * 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
|
219 * 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
|
220 * |
9082 | 221 * @param winfo |
222 * A WINFO Artifact. | |
223 * @param wqkms | |
224 * A WQKms object that should be prepared. | |
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 */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
226 public String getColumnTitle(final WINFOArtifact winfo, final WQKms wqkms) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
227 log.debug("WaterlevelExporter.getColumnTitle"); |
2035
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
228 |
9082 | 229 final String name = wqkms.getName(); |
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
|
230 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
231 log.debug("Name of WQKms = '" + name + "'"); |
2035
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
232 |
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
|
233 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
|
234 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
|
235 } |
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
|
236 |
9082 | 237 final Matcher m = NUMBERS_PATTERN.matcher(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
|
238 |
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 if (m.matches()) { |
9082 | 240 final String raw = m.group(1); |
2035
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
241 |
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
242 try { |
9082 | 243 final double v = Double.valueOf(raw); |
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
|
244 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
245 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
|
246 |
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 if (nmv != null && nmv.length() > 0) { |
9082 | 248 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
|
249 nmv += "=" + String.valueOf(v); |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
250 log.debug("Set named main value '" + nmv + "'"); |
2035
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
251 |
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
|
252 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
|
253 } |
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
|
254 } |
9082 | 255 catch (final NumberFormatException nfe) { |
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
|
256 // 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
|
257 } |
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
258 } |
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
|
259 |
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
|
260 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
|
261 } |
3ebbe497d7f7
#252 Set titles in waterlevel exports to named main values if those are existing for given Q values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
749
diff
changeset
|
262 |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
263 /** |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
264 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
265 */ |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
266 @Deprecated |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
267 public String getCSVRowTitle(final WINFOArtifact winfo, final WQKms wqkms) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
268 log.debug("WaterlevelExporter.prepareNamedValue"); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
269 |
9082 | 270 final String name = wqkms.getName(); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
271 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
272 log.debug("Name of WQKms = '" + name + "'"); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
273 |
9082 | 274 final 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
|
275 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
276 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
|
277 return localizeWQKms(winfo, wqkms); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
278 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
279 |
9082 | 280 final Double v = wqkms.getRawValue(); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
281 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
282 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
|
283 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
284 if (nmv != null && nmv.length() > 0) { |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
285 nmv = RiverUtils.stripNamedMainValue(nmv); |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
286 log.debug("Set named main value '" + nmv + "'"); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
287 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
288 return nmv; |
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 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
291 return localizeWQKms(winfo, wqkms); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
292 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
293 |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
294 /** |
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
295 * 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
|
296 * format. |
9082 | 297 * |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
298 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
299 */ |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
300 @Deprecated |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
301 public String localizeWQKms(final WINFOArtifact winfo, final WQKms wqkms) { |
9082 | 302 final WQ_MODE wqmode = RiverUtils.getWQMode(winfo); |
303 final Double rawValue = wqkms.getRawValue(); | |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
304 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
305 if (rawValue == null) { |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
306 return wqkms.getName(); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
307 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
308 |
9082 | 309 final NumberFormat nf = Formatter.getRawFormatter(this.context); |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
310 |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
311 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
|
312 return "W=" + nf.format(rawValue); |
9082 | 313 } else { |
2087
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
314 return "Q=" + nf.format(rawValue); |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
315 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
316 } |
bda04ae1154f
#196 Localized the WQ labels in CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2068
diff
changeset
|
317 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
318 private final boolean isQ() { |
9485 | 319 final WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact) this.master); |
320 return mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE; | |
9459
f06e3766997f
fallunterscheidung isQ - fixWaterlevelExporter
gernotbelger
parents:
9457
diff
changeset
|
321 } |
f06e3766997f
fallunterscheidung isQ - fixWaterlevelExporter
gernotbelger
parents:
9457
diff
changeset
|
322 |
701
dad1a2c88f9f
Base WST/CSV exports on facets. TODO: generate the facets.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
664
diff
changeset
|
323 @Override |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
324 public void writeCSVData(final CSVWriter writer) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
325 log.info("WaterlevelExporter.writeData"); |
9082 | 326 final WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact) this.master); |
327 final boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE; | |
9485 | 328 final boolean isQ = isQ(); |
9459
f06e3766997f
fallunterscheidung isQ - fixWaterlevelExporter
gernotbelger
parents:
9457
diff
changeset
|
329 |
9082 | 330 final RiverUtils.WQ_INPUT input = RiverUtils.getWQInputMode((D4EArtifact) this.master); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
331 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
|
332 writeCSVHeader(writer, atGauge, isQ); |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
333 |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
334 Double first = Double.NaN; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
335 Double last = Double.NaN; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
336 |
9082 | 337 for (final WQKms[] tmp : this.data) { |
338 for (final 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
|
339 wQKms2CSV(writer, wqkms, atGauge, isQ); |
9082 | 340 final double[] firstLast = wqkms.getFirstLastKM(); |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
341 if (first.isNaN()) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
342 /* Initialize */ |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
343 first = firstLast[0]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
344 last = firstLast[1]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
345 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
346 if (firstLast[0] > firstLast[1]) { |
9082 | 347 /* |
348 * Calculating upstream we assert that it is | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
349 * impossible that the direction changes during this |
9082 | 350 * loop |
351 */ | |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
352 first = Math.max(first, firstLast[0]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
353 last = Math.min(last, firstLast[1]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
354 } else if (firstLast[0] < firstLast[1]) { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
355 first = Math.min(first, firstLast[0]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
356 last = Math.max(last, firstLast[1]); |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
357 } else { |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
358 first = last = firstLast[0]; |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
359 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
360 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
361 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
362 /* Append the official fixing at the bottom */ |
9082 | 363 for (final WQKms wqkms : this.officalFixings) { |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
364 wQKms2CSV(writer, filterWQKms(wqkms, first, last), atGauge, isQ); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
365 } |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
366 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
367 |
9082 | 368 /** |
369 * Filter a wqkms object to a distance. | |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
370 * |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
371 * To handle upstream / downstream and to limit |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
372 * the officialFixings to the calculation distance |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
373 * 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
|
374 * with the relevant data. |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
375 * |
9082 | 376 * @param wqkms: |
377 * The WQKms Object to filter | |
378 * @param first: | |
379 * The fist kilometer of the range | |
380 * @param last: | |
381 * The last kilometer of the range | |
6603
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 * @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
|
384 */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
385 public final WQKms filterWQKms(final WQKms wqkms, final Double first, final Double last) { |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
386 if (first.isNaN() || last.isNaN()) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
387 log.warn("Filtering official fixing without valid first/last."); |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
388 return wqkms; |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
389 } |
9082 | 390 final int firstIdx = first > last ? wqkms.size() - 1 : 0; |
391 final int lastIdx = first > last ? 0 : wqkms.size() - 1; | |
392 final WQKms filtered = new WQKms(wqkms.size()); | |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
393 filtered.setName(wqkms.getName()); |
9082 | 394 double[] dp = new double[3]; |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
395 |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
396 if (first > last) { |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
397 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
|
398 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
|
399 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
|
400 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
|
401 } |
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
402 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
403 } 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
|
404 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
|
405 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
|
406 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
|
407 filtered.add(dp[0], dp[1], dp[2]); |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
408 } |
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
409 } |
6601
5ecc6d4d73f2
Add official fixings to Waterlevel CSV Export (issue1384)
Andre Heinecke <aheinecke@intevation.de>
parents:
6576
diff
changeset
|
410 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
411 return filtered; |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
412 } |
6603
90756201c488
Factor out filtering code in WaterlevelExporter
Andre Heinecke <aheinecke@intevation.de>
parents:
6601
diff
changeset
|
413 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
414 public void writeCSVMeta(final CSVWriter writer) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
415 log.info("WaterlevelExporter.writeCSVMeta"); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
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 |
9082 | 419 final CallMeta meta = this.context.getMeta(); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
420 |
9082 | 421 final D4EArtifact flys = (D4EArtifact) this.master; |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
422 |
9082 | 423 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_RESULT, CSV_META_RESULT, new Object[] { RiverUtils.getRivername(flys) }) }); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
424 |
9082 | 425 final Locale locale = Resources.getLocale(meta); |
426 final DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT, locale); | |
427 | |
428 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_CREATION, CSV_META_CREATION, new Object[] { df.format(new Date()) }) }); | |
429 | |
430 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_CALCULATIONBASE, CSV_META_CALCULATIONBASE, new Object[] { "" }) // TODO what is required | |
431 // at this place? | |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
432 }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
433 |
9082 | 434 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_RIVER, CSV_META_RIVER, 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
|
435 |
9082 | 436 final RangeAccess rangeAccess = new RangeAccess(flys); |
437 final double[] kms = rangeAccess.getKmRange(); | |
438 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_RANGE, CSV_META_RANGE, new Object[] { kms[0], kms[kms.length - 1] }) }); | |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
439 |
9082 | 440 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_GAUGE, CSV_META_GAUGE, 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
|
441 |
9040 | 442 // TODO: code extracted into WaterlevelDescriptionBuilder, should be used instead. |
9082 | 443 final RiverUtils.WQ_MODE wq = RiverUtils.getWQMode(flys); |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
444 if (wq == RiverUtils.WQ_MODE.QFREE || wq == RiverUtils.WQ_MODE.QGAUGE) { |
9082 | 445 final double[] qs = RiverUtils.getQs(flys); |
446 final 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
|
447 |
2423
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
448 String data = ""; |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
449 |
9082 | 450 if ((input == RiverUtils.WQ_INPUT.ADAPTED || input == RiverUtils.WQ_INPUT.RANGE) && qs != null && qs.length > 0) { |
2423
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
451 data = String.valueOf(qs[0]); |
9082 | 452 data += " - " + String.valueOf(qs[qs.length - 1]); |
453 } 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
|
454 data = String.valueOf(qs[0]); |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
455 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
|
456 data += ", " + String.valueOf(qs[i]); |
ac528b883b47
Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2290
diff
changeset
|
457 } |
9082 | 458 } else { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
459 log.warn("Could not determine Q range!"); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
460 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
461 |
9082 | 462 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_Q, CSV_META_Q, new Object[] { data }) }); |
463 } else { | |
464 final 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
|
465 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
466 String lower = ""; |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
467 String upper = ""; |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
468 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
469 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
|
470 lower = String.valueOf(ws[0]); |
9082 | 471 upper = String.valueOf(ws[ws.length - 1]); |
472 } else { | |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
473 log.warn("Could not determine W range!"); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
474 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
475 |
9082 | 476 writer.writeNext(new String[] { Resources.getMsg(meta, CSV_META_W, CSV_META_W, new Object[] { lower, upper }) }); |
2045
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
477 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
478 |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
479 writer.writeNext(new String[] { "" }); |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
480 } |
d13be39cfd1d
#242 Added header with meta information into CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2038
diff
changeset
|
481 |
4979
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
482 /** |
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
483 * 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
|
484 * gauge or at a location. |
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
485 */ |
9082 | 486 protected void writeCSVHeader(final CSVWriter writer, final boolean atGauge, final boolean isQ) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
487 log.info("WaterlevelExporter.writeCSVHeader"); |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
488 |
9082 | 489 final String unit = RiverUtils.getRiver((D4EArtifact) this.master).getWstUnit().getName(); |
5133
8e52b4829cd1
Fix flys/issue1228: Units in tabular calculation output.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5131
diff
changeset
|
490 |
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
|
491 if (atGauge) { |
9082 | 492 writer.writeNext(new String[] { msg(CSV_KM_HEADER, DEFAULT_CSV_KM_HEADER), msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER, new Object[] { unit }), |
493 msg(CSV_Q_HEADER, DEFAULT_CSV_Q_HEADER), | |
494 | |
495 // FIXME: use WaterlevelDescriptionBuilder instead and also remove all this duplicate code. | |
496 (isQ ? msg(CSV_Q_DESC_HEADER, DEFAULT_CSV_Q_DESC_HEADER) : msg(CSV_W_DESC_HEADER, DEFAULT_CSV_W_DESC_HEADER)), | |
497 msg(CSV_LOCATION_HEADER, DEFAULT_CSV_LOCATION_HEADER), msg(CSV_GAUGE_HEADER, DEFAULT_CSV_GAUGE_HEADER) }); | |
498 } else { | |
499 writer.writeNext(new String[] { 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
|
500 // TODO flys/issue1128 (unit per river) |
9082 | 501 msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER, new Object[] { unit }), msg(CSV_Q_HEADER, DEFAULT_CSV_Q_HEADER), |
502 msg(CSV_LOCATION_HEADER, DEFAULT_CSV_LOCATION_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
|
503 } |
416
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
504 } |
340dc41a7ea3
The CSV exports will now have headers.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
391
diff
changeset
|
505 |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
506 /** Linearly search for gauge which is valid at km. */ |
9082 | 507 private static Gauge findGauge(final double km, final List<Gauge> gauges) { |
508 for (final Gauge gauge : gauges) { | |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
509 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
|
510 return gauge; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
511 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
512 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
513 return null; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
514 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
515 |
9082 | 516 private static Segment findSegment(final double km, final List<Segment> segments) { |
517 for (final Segment segment : segments) { | |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
518 if (segment.inside(km)) { |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
519 return segment; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
520 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
521 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
522 return null; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
523 } |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
524 |
9485 | 525 protected void writeRow4(final CSVWriter writer, final double wqkm[], final D4EArtifact flys, final Gauge gauge, final boolean isQ) { |
9082 | 526 final NumberFormat kmf = getKmFormatter(); |
527 final NumberFormat wf = getWFormatter(); | |
528 final NumberFormat qf = getQFormatter(); | |
529 writer.writeNext(new String[] { kmf.format(wqkm[2]), wf.format(wqkm[0]), qf.format(RiverUtils.roundQ(wqkm[1])), | |
530 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
|
531 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
532 |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
533 /** Write an csv-row at gauge location. */ |
9485 | 534 protected void writeRow6(final CSVWriter writer, final double wqkm[], final String wOrQDesc, final D4EArtifact flys, final String gaugeName, |
535 final Gauge gauge, final boolean isQ) { | |
9082 | 536 final NumberFormat kmf = getKmFormatter(); |
537 final NumberFormat wf = getWFormatter(); | |
538 final NumberFormat qf = getQFormatter(); | |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
539 |
9082 | 540 writer.writeNext(new String[] { kmf.format(wqkm[2]), wf.format(wqkm[0]), qf.format(RiverUtils.roundQ(wqkm[1])), wOrQDesc, |
9485 | 541 RiverUtils.getLocationDescription(flys, wqkm[2]), gaugeName }); |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
542 } |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
543 |
8932
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
544 /** |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
545 * @deprecated Use {@link WaterlevelDescriptionBuilder} instead. |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
546 */ |
8731c3dabb56
Extracting some winfo logic without breaking old code
gernotbelger
parents:
8856
diff
changeset
|
547 @Deprecated |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
548 public final String getDesc(final WQKms wqkms, final boolean isQ) { |
9082 | 549 final D4EArtifact flys = (D4EArtifact) this.master; |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
550 String colDesc = ""; |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
551 |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
552 if (flys instanceof WINFOArtifact && isQ) { |
9082 | 553 colDesc = getCSVRowTitle((WINFOArtifact) flys, wqkms); |
554 } else if (!isQ) { | |
555 final Double value = RiverUtils.getValueFromWQ(wqkms); | |
556 colDesc = (value != null) ? Formatter.getWaterlevelW(this.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
|
557 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
558 |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
559 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
|
560 if (wqkms != null && wqkms.getRawValue() != null) { |
9082 | 561 final WINFOArtifact winfo = (WINFOArtifact) flys; |
562 colDesc = RiverUtils.getNamedMainValue(winfo, wqkms.getRawValue()); | |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
563 // 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
|
564 if (colDesc == null) { |
9082 | 565 final Double value = RiverUtils.getValueFromWQ(wqkms); |
566 colDesc = (value != null) ? Formatter.getWaterlevelW(this.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
|
567 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
568 } |
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
569 } |
6610
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
570 if (colDesc != null) { |
9082 | 571 /* |
572 * Quick hack. Can be removed when database strings are | |
573 * adapted or left in here as it should never be harmful. | |
574 */ | |
6610
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
575 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
|
576 } |
8d88db1f5d36
Add quick hack to fix the exported name of Amtl.Fixierungen
Andre Heinecke <aheinecke@intevation.de>
parents:
6608
diff
changeset
|
577 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
578 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
|
579 } |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
580 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
581 private List<Segment> getSegments(final D4EArtifact flys) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
582 if (flys instanceof AbstractFixBunduArtifact) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
583 // Get W/Q input per gauge for this case. |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
584 final FixRealizingAccess fixAccess = new FixRealizingAccess(flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
585 return fixAccess.getSegments(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
586 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
587 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
588 return null; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
589 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
590 |
3252
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
591 /** |
62c9bcef0680
Fix issue705 (maín value names also in w/q-range mode).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2764
diff
changeset
|
592 * 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
|
593 */ |
9082 | 594 protected void wQKms2CSV(final CSVWriter writer, final WQKms wqkms, final boolean atGauge, final boolean isQ) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
595 log.debug("WaterlevelExporter.wQKms2CSV"); |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
596 |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
597 // Skip constant data. |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
598 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
599 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
600 } |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
601 |
9082 | 602 final int size = wqkms.size(); |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
603 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
|
604 |
9082 | 605 final D4EArtifact flys = (D4EArtifact) this.master; |
606 final RangeAccess rangeAccess = new RangeAccess(flys); | |
8759
2faf6cef6f5f
(issue1801) Remove indirection via RiverUtils for obtaining reference gauge.
Tom Gottfried <tom@intevation.de>
parents:
8362
diff
changeset
|
607 |
9082 | 608 final List<Gauge> gauges = RiverUtils.getGauges(flys); |
8759
2faf6cef6f5f
(issue1801) Remove indirection via RiverUtils for obtaining reference gauge.
Tom Gottfried <tom@intevation.de>
parents:
8362
diff
changeset
|
609 |
9536
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
610 Gauge gauge = rangeAccess.getRiver().determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange()); |
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
611 |
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
612 // REMARK gauge may be null when rangeAccess starts outside any gauge range |
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
613 if (gauge == null) |
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
614 gauge = rangeAccess.getRiver().determineRefGauge(wqkms.getKms(), rangeAccess.isRange()); |
9082 | 615 |
9459
f06e3766997f
fallunterscheidung isQ - fixWaterlevelExporter
gernotbelger
parents:
9457
diff
changeset
|
616 final String gaugeName = gauge.getName(); // RANDOMLY CHRASHES HERE, gauge is randomly null (especially on heavy load) - on production system as well |
f06e3766997f
fallunterscheidung isQ - fixWaterlevelExporter
gernotbelger
parents:
9457
diff
changeset
|
617 // (it seems to) |
9536
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
618 // REMARK "randomly" crashes: see REMARK above |
aa23225fd85f
Fixed exception in wq csv export (raising error_no_export_found) in cases when the calc range starts outside any gauge range
mschaefer
parents:
9486
diff
changeset
|
619 |
9082 | 620 String desc = ""; |
621 final String notinrange = msg(CSV_NOT_IN_GAUGE_RANGE, DEFAULT_CSV_NOT_IN_GAUGE_RANGE); | |
2066
2b6a0de47379
Improved the WaterlevelExporter: added range check for W/Q at gauge.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
2065
diff
changeset
|
622 |
9082 | 623 final double a = gauge.getRange().getA().doubleValue(); |
624 final double b = gauge.getRange().getB().doubleValue(); | |
625 final long startTime = System.currentTimeMillis(); | |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
626 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
627 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
|
628 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
629 boolean isFixRealize = false; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
630 final List<Segment> segments = getSegments(flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
631 if (segments != null && !segments.isEmpty()) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
632 isFixRealize = true; |
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
|
633 } |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
634 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
|
635 |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
636 // 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
|
637 // is a good time saving heuristic. |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
638 Segment lastSegment = null; |
9082 | 639 Gauge lastGauge = null; |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
640 |
9082 | 641 final NumberFormat nf = Formatter.getFormatter(this.context.getMeta(), 0, 0); |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
642 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
643 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
|
644 result = wqkms.get(i, result); |
9082 | 645 final double km = result[2]; |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
646 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
647 if (segments != null) { |
9082 | 648 final Segment found = lastSegment != null && lastSegment.inside(km) ? lastSegment : findSegment(km, segments); |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
649 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
650 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
|
651 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
|
652 } |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
653 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
|
654 } |
15e856a64cdd
Partly fix flys/issue1142: Include specified W values at gauge for fix.real.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4979
diff
changeset
|
655 |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
656 String gaugeN; |
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
657 if (isFixRealize) { |
9082 | 658 final Gauge found = lastGauge != null && lastGauge.getRange().contains(km) ? lastGauge : findGauge(km, gauges); |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
659 |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
660 gaugeN = found != null ? found.getName() : notinrange; |
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
661 lastGauge = found; |
9082 | 662 } else { |
4979
4c76c5f69eaf
WaterlevelExporter: Doc and issue-TODO.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4859
diff
changeset
|
663 // TODO issue1114: Take correct gauge |
9082 | 664 gaugeN = km >= a && km <= b ? gaugeName : notinrange; |
5112
ae25e23a1546
WaterlevelExporter: Unpolished fix for flys/issue1131: gaugename in csv.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5107
diff
changeset
|
665 } |
9485 | 666 writeRow6(writer, result, desc, flys, gaugeN, gauge, isQ); |
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
|
667 } |
9082 | 668 } else { // Not at gauge. |
5587
7b1c5fe4ebf3
Simplified inner loop of water level exporter.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5425
diff
changeset
|
669 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
|
670 result = wqkms.get(i, result); |
9485 | 671 writeRow4(writer, result, flys, gauge, isQ); |
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
|
672 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
673 } |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
674 |
9082 | 675 final long stopTime = System.currentTimeMillis(); |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
676 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
677 if (log.isDebugEnabled()) { |
9082 | 678 log.debug("Writing CSV took " + (stopTime - startTime) / 1000f + " secs."); |
2144
a4bdf7d8527e
Use FastAnnotations for LocationProvider.
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
2087
diff
changeset
|
679 } |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
680 } |
418
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
681 |
e0fec407a280
ISSUE-53 Formatted number values of CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
416
diff
changeset
|
682 /** |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
683 * 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
|
684 */ |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
685 public void generateWST() throws IOException { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
686 log.info("WaterlevelExporter.generateWST"); |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
687 |
9082 | 688 final int cols = this.data.get(0).length + this.officalFixings.size(); |
689 final WstWriter writer = new WstWriter(cols); | |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
690 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
691 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
|
692 |
9082 | 693 writer.write(this.out); |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
694 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
695 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
696 public void writeWSTData(final WstWriter writer) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
697 log.debug("WaterlevelExporter.writeWSTData"); |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
698 |
749
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
699 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
|
700 |
9082 | 701 for (final WQKms[] tmp : this.data) { |
702 for (final WQKms wqkms : tmp) { | |
5105
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
703 if (wqkms instanceof ConstantWQKms) { |
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
704 continue; |
34baad34987f
Skip ConstantWQKms (Umhuellende) in exports.
Raimund Renkert <rrenkert@intevation.de>
parents:
5103
diff
changeset
|
705 } |
9082 | 706 final int size = wqkms != null ? wqkms.size() : 0; |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
707 |
450
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
708 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
|
709 |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
710 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
|
711 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
|
712 |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
713 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
|
714 } |
749
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
715 |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
716 if (wqkms instanceof WQCKms) { |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
717 addWSTColumn(writer, wqkms); |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
718 |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
719 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
|
720 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
|
721 |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
722 writer.addCorrected(result); |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
723 } |
72bcbc308501
The WST export contains the corrected W values now.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
709
diff
changeset
|
724 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
725 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
726 } |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
727 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
728 // 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
|
729 // |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
730 // 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
|
731 // for details. |
9082 | 732 for (final WQKms wqkms : this.officalFixings) { |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
733 // 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
|
734 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
|
735 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
736 // Get all lines from the calculation |
9082 | 737 final Map<Double, WstLine> calcLines = writer.getLines(); |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
738 |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
739 // All KM values where we have a point for |
9082 | 740 final TDoubleArrayList officialKms = wqkms.allKms(); |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
741 |
9082 | 742 for (final Map.Entry<Double, WstLine> entry : calcLines.entrySet()) { |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
743 // 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
|
744 // so lets not spend time optimizing too much,.. *hides* |
9082 | 745 final double km = entry.getKey().doubleValue(); |
746 final int idx = officialKms.indexOf(km); | |
7604
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
747 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
|
748 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
|
749 } |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
750 } |
05549a84ee83
(issue1620) Add export of official lines in WST as specified
Andre Heinecke <aheinecke@intevation.de>
parents:
7254
diff
changeset
|
751 } |
446
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
752 } |
c0bec245f608
Implemented writer that creates WSTs and enabled the WaterlevelExporter to create those.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
445
diff
changeset
|
753 |
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
|
754 /** |
6576 | 755 * 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
|
756 * 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
|
757 * 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
|
758 * 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
|
759 * <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
|
760 * |
9082 | 761 * @param writer |
762 * The WstWriter. | |
763 * @param wqkms | |
764 * The new WST column. | |
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
|
765 */ |
9082 | 766 protected void addWSTColumn(final WstWriter writer, final WQKms wqkms) { |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
767 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
768 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
769 } |
9082 | 770 if (this.master instanceof WINFOArtifact) { |
771 writer.addColumn(getColumnTitle((WINFOArtifact) this.master, wqkms)); | |
772 } else { | |
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
|
773 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
|
774 } |
450
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
775 } |
c8bb38115290
Enabled the discharge longitudinal section to be exported as WST.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
447
diff
changeset
|
776 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
777 @Override |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
778 protected void writePDF(final OutputStream out) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
779 log.debug("write PDF"); |
2185
a9a8df1473fd
Added i18n support to PDF report export.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2182
diff
changeset
|
780 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
781 final boolean isQ = isQ(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
782 final MetaAndTableJRDataSource source = new MetaAndTableJRDataSource(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
783 final String jasperFile = !isQ ? "/jasper/templates/waterlevel_new.jrxml" : "/jasper/templates/fix_waterlevel.jrxml"; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
784 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
785 ((D4EArtifact) this.master).getData("calculation.mode"); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
786 if ((this.master instanceof WINFOArtifact)) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
787 addMetaData(source, "calc.surface.curve"); // Wasserspiegellage |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
788 } else if |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
789 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
790 (this.master instanceof AbstractFixBunduArtifact) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
791 addMetaData(source, ((AbstractFixBunduArtifact) this.master).getCalculationModeString());// "calculation.vollmer"); // ausgelagerte |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
792 // Wasserspiegellage |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
793 // else |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
794 // addMetaData(source, "calculation.analysis"); // Fixierungsanalyse |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
795 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
796 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
797 try { |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
798 final List<String[]> sorted = getRows(); // Custom Result could be nice, too... |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
799 for (final String[] list : sorted) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
800 source.addData(list); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
801 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
802 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
803 final JasperReporter reporter = new JasperReporter(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
804 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
805 final JasperDesigner d = reporter.addReport(jasperFile, source); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
806 d.removeColumn("delete"); // I don't want to mess with getRows(), so I prefer deleting the unwanted row directly in the report. |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
807 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
808 reporter.exportPDF(this.out); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
809 } |
9082 | 810 catch (final JRException je) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
811 log.warn("Error generating PDF Report!", je); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
812 } |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
813 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
814 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
815 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
816 private List<String[]> getRows() { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
817 final List<String[]> list = new ArrayList<>(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
818 final WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact) this.master); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
819 final boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
820 final boolean isQ = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
821 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
822 Double first = Double.NaN; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
823 Double last = Double.NaN; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
824 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
825 for (final WQKms[] tmp : this.data) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
826 for (final WQKms wqkms : tmp) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
827 list.addAll(getRows2(wqkms, atGauge, isQ)); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
828 final double[] firstLast = wqkms.getFirstLastKM(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
829 if (first.isNaN()) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
830 /* Initialize */ |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
831 first = firstLast[0]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
832 last = firstLast[1]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
833 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
834 if (firstLast[0] > firstLast[1]) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
835 /* |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
836 * Calculating upstream we assert that it is |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
837 * impossible that the direction changes during this |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
838 * loop |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
839 */ |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
840 first = Math.max(first, firstLast[0]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
841 last = Math.min(last, firstLast[1]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
842 } else if (firstLast[0] < firstLast[1]) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
843 first = Math.min(first, firstLast[0]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
844 last = Math.max(last, firstLast[1]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
845 } else { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
846 first = last = firstLast[0]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
847 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
848 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
849 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
850 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
851 /* Append the official fixing at the bottom */ |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
852 for (final WQKms wqkms : this.officalFixings) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
853 list.addAll(getRows2(filterWQKms(wqkms, first, last), atGauge, isQ)); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
854 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
855 return list; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
856 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
857 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
858 private List<String[]> getRows2(final WQKms wqkms, final boolean atGauge, final boolean isQ) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
859 log.debug("WaterlevelExporter.addWKmsData"); // OLD CODE :-/ |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
860 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
861 final List<String[]> list = new ArrayList<>(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
862 // Skip constant data. |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
863 if (wqkms instanceof ConstantWQKms) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
864 return null; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
865 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
866 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
867 final NumberFormat kmf = getKmFormatter(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
868 final NumberFormat wf = getWFormatter(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
869 final NumberFormat qf = getQFormatter(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
870 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
871 final int size = wqkms.size(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
872 double[] result = new double[3]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
873 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
874 final D4EArtifact flys = (D4EArtifact) this.master; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
875 final RangeAccess rangeAccess = new RangeAccess(flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
876 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
877 final Gauge gauge = rangeAccess.getRiver().determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange()); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
878 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
879 final String gaugeName = gauge.getName(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
880 String desc = ""; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
881 final String notinrange = msg(CSV_NOT_IN_GAUGE_RANGE, DEFAULT_CSV_NOT_IN_GAUGE_RANGE); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
882 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
883 final double a = gauge.getRange().getA().doubleValue(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
884 final double b = gauge.getRange().getB().doubleValue(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
885 final WaterlevelDescriptionBuilder wldb = new WaterlevelDescriptionBuilder(flys, this.context); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
886 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
887 desc = wldb.getDesc(wqkms);// class getDesc(wqkms, isQ); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
888 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
889 Segment lastSegment = null; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
890 final Gauge lastGauge = null; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
891 final List<Segment> segments = getSegments(flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
892 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
893 final NumberFormat nf = Formatter.getFormatter(this.context.getMeta(), 0, 0); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
894 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
895 for (int i = 0; i < size; ++i) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
896 result = wqkms.get(i, result); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
897 final double km = result[2]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
898 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
899 if (segments != null) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
900 final Segment found = lastSegment != null && lastSegment.inside(km) ? lastSegment : findSegment(km, segments); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
901 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
902 if (found != null) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
903 desc = nf.format(found.getValues()[0]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
904 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
905 lastSegment = found; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
906 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
907 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
908 final double q = result[1]; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
909 final String waterlevel = this.getWaterlevel(q, gauge); // THIS IS NEW (and makes common super method |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
910 // difficult) |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
911 if (atGauge) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
912 list.add(new String[] { kmf.format(result[2]), wf.format(result[0]), waterlevel, qf.format(RiverUtils.roundQ(result[1])), desc, |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
913 RiverUtils.getLocationDescription(flys, result[2]), result[2] >= a && result[2] <= b ? gaugeName : notinrange }); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
914 } else { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
915 list.add(new String[] { kmf.format(result[2]), wf.format(result[0]), waterlevel, qf.format(RiverUtils.roundQ(result[1])), desc, |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
916 RiverUtils.getLocationDescription(flys, result[2]), result[2] >= a && result[2] <= b ? gaugeName : notinrange }); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
917 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
918 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
919 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
920 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
921 return list; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
922 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
923 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
924 protected final void addMetaData(final MetaAndTableJRDataSource source, final String calculation) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
925 final D4EArtifact flys = (D4EArtifact) this.master; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
926 final String user = CalculationUtils.findArtifactUser(this.context, flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
927 final RangeAccess ra = new RangeAccess(flys); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
928 final RiverInfo ri = new RiverInfo(ra.getRiver()); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
929 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
930 final DefaultCalculationResults results = new DefaultCalculationResults(msg(calculation), user, ri, ra.getRange()); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
931 final ExportContextPDF contextPdf = new ExportContextPDF(this.context, results); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
932 contextPdf.addJRMetaDataDefaults(source); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
933 contextPdf.addJRMetaDataForModules(source); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
934 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
935 /* column headings */ |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
936 contextPdf.addJRMetadata(source, "station_header", GeneralResultType.station); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
937 contextPdf.addJRMetadata(source, "fix_w", msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER, new Object[] { ri.getWstUnit() })); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
938 contextPdf.addJRMetadata(source, "w_at_gauge_header", msg("fix.export.csv.w_at_gauge")); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
939 contextPdf.addJRMetadata(source, "fix_q", msg(CSV_Q_HEADER)); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
940 contextPdf.addJRMetadata(source, "waterlevel_name_header", msg("common.export.csv.header.mainvalue_label")); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
941 contextPdf.addJRMetadata(source, "location_header", msg("common.export.csv.header.location")); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
942 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
943 contextPdf.addJRMetadata(source, "w_at_gauge_header_2", msg("export.waterlevel.csv.header.w.desc")); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
944 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
945 contextPdf.addJRMetadata(source, "location_header", msg("common.export.csv.header.location")); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
946 contextPdf.addJRMetadata(source, "gauge_header", msg("common.export.csv.header.gauge")); |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
947 |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
948 } |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
949 |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
950 private WKmsJRDataSource createJRData() { |
9082 | 951 final WKmsJRDataSource source = new WKmsJRDataSource(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
952 |
9082 | 953 final WQ_MODE mode = RiverUtils.getWQMode((D4EArtifact) this.master); |
954 final boolean atGauge = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.WGAUGE; | |
955 final boolean isQ = mode == WQ_MODE.QGAUGE || mode == WQ_MODE.QFREE; | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
956 |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
957 Double first = Double.NaN; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
958 Double last = Double.NaN; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
959 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
960 addMetaData(source); |
9082 | 961 for (final WQKms[] tmp : this.data) { |
962 for (final WQKms wqkms : tmp) { | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
963 addWKmsData(wqkms, atGauge, isQ, source); |
9082 | 964 final double[] firstLast = wqkms.getFirstLastKM(); |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
965 if (first.isNaN()) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
966 /* Initialize */ |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
967 first = firstLast[0]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
968 last = firstLast[1]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
969 } |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
970 if (firstLast[0] > firstLast[1]) { |
9082 | 971 /* |
972 * Calculating upstream we assert that it is | |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
973 * impossible that the direction changes during this |
9082 | 974 * loop |
975 */ | |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
976 first = Math.max(first, firstLast[0]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
977 last = Math.min(last, firstLast[1]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
978 } else if (firstLast[0] < firstLast[1]) { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
979 first = Math.min(first, firstLast[0]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
980 last = Math.max(last, firstLast[1]); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
981 } else { |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
982 first = last = firstLast[0]; |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
983 } |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
984 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
985 } |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
986 |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
987 /* Append the official fixing at the bottom */ |
9082 | 988 for (final WQKms wqkms : this.officalFixings) { |
6608
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
989 addWKmsData(filterWQKms(wqkms, first, last), atGauge, isQ, source); |
3d23f606512f
Add official Fixings to PDF Export
Andre Heinecke <aheinecke@intevation.de>
parents:
6607
diff
changeset
|
990 } |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
991 return source; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
992 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
993 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
994 public void addMetaData(final WKmsJRDataSource source) { |
9082 | 995 final CallMeta meta = this.context.getMeta(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
996 |
9082 | 997 final D4EArtifact flys = (D4EArtifact) this.master; |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
998 |
9082 | 999 source.addMetaData("river", RiverUtils.getRivername(flys)); |
1000 | |
1001 final Locale locale = Resources.getLocale(meta); | |
1002 final DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT, locale); | |
1003 final NumberFormat kmf = getKmFormatter(); | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1004 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1005 source.addMetaData("date", df.format(new Date())); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1006 |
9082 | 1007 final RangeAccess rangeAccess = new RangeAccess(flys); |
1008 final double[] kms = rangeAccess.getKmRange(); | |
1009 source.addMetaData("range", kmf.format(kms[0]) + " - " + kmf.format(kms[kms.length - 1])); | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1010 |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1011 source.addMetaData("w_at_gauge_header", Resources.getMsg(meta, "fix.export.csv.w_at_gauge")); // dürfte kein Problem sein für Vorlagen, die kein |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1012 // "w_at_gauge" |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1013 // haben |
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1014 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
1015 source.addMetaData("gauge", RiverUtils.getGaugename(flys)); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1016 |
9082 | 1017 source.addMetaData("calculation", Resources.getMsg(locale, PDF_HEADER_MODE, "Waterlevel")); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1018 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1019 |
9082 | 1020 protected void addWKmsData(final WQKms wqkms, final boolean atGauge, final boolean isQ, final WKmsJRDataSource source) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
1021 log.debug("WaterlevelExporter.addWKmsData"); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1022 |
4836
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1023 // Skip constant data. |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1024 if (wqkms instanceof ConstantWQKms) { |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1025 return; |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1026 } |
01e82da3f919
Ignore constant WQKms in CSV and PDF output.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4433
diff
changeset
|
1027 |
9082 | 1028 final NumberFormat kmf = getKmFormatter(); |
1029 final NumberFormat wf = getWFormatter(); | |
1030 final NumberFormat qf = getQFormatter(); | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1031 |
9082 | 1032 final int size = wqkms.size(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1033 double[] result = new double[3]; |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1034 |
9082 | 1035 final D4EArtifact flys = (D4EArtifact) this.master; |
1036 final RangeAccess rangeAccess = new RangeAccess(flys); | |
8759
2faf6cef6f5f
(issue1801) Remove indirection via RiverUtils for obtaining reference gauge.
Tom Gottfried <tom@intevation.de>
parents:
8362
diff
changeset
|
1037 |
9082 | 1038 final Gauge gauge = rangeAccess.getRiver().determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange()); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1039 |
9082 | 1040 final String gaugeName = gauge.getName(); |
1041 String desc = ""; | |
1042 final String notinrange = msg(CSV_NOT_IN_GAUGE_RANGE, DEFAULT_CSV_NOT_IN_GAUGE_RANGE); | |
1043 | |
1044 final double a = gauge.getRange().getA().doubleValue(); | |
1045 final double b = gauge.getRange().getB().doubleValue(); | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1046 |
6606
b4fcc9308d00
Factor out description getting code from csv export and reuse for pdf
Andre Heinecke <aheinecke@intevation.de>
parents:
6605
diff
changeset
|
1047 desc = getDesc(wqkms, isQ); |
9082 | 1048 final long startTime = System.currentTimeMillis(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1049 |
9082 | 1050 for (int i = 0; i < size; i++) { |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1051 result = wqkms.get(i, result); |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1052 |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1053 if (atGauge) { |
9082 | 1054 source.addData(new String[] { kmf.format(result[2]), wf.format(result[0]), qf.format(RiverUtils.roundQ(result[1])), desc, |
1055 RiverUtils.getLocationDescription(flys, result[2]), result[2] >= a && result[2] <= b ? gaugeName : notinrange }); | |
1056 } else { | |
1057 source.addData(new String[] { kmf.format(result[2]), wf.format(result[0]), qf.format(RiverUtils.roundQ(result[1])), desc, | |
1058 RiverUtils.getLocationDescription(flys, result[2]), result[2] >= a && result[2] <= b ? gaugeName : notinrange }); | |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1059 } |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1060 |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1061 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1062 |
9082 | 1063 final long stopTime = System.currentTimeMillis(); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1064 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7639
diff
changeset
|
1065 if (log.isDebugEnabled()) { |
9082 | 1066 log.debug("Writing PDF data took " + (stopTime - startTime) / 1000f + " secs."); |
2176
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1067 } |
65dac9cf6ff5
Issue 138.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2144
diff
changeset
|
1068 } |
9457
65f28328c9a3
ausgelagerte Wasserspiegellage AWSPL neue Spalte
gernotbelger
parents:
9323
diff
changeset
|
1069 |
9486
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1070 protected final String getWaterlevel(final double discharge, final Gauge gauge) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1071 final NumberFormat formatter = Formatter.getWaterlevelW(this.context); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1072 final Double waterlevel = this.getWforGaugeAndQ(gauge, discharge); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1073 if (waterlevel != null) |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1074 return formatter.format(waterlevel); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1075 return ""; |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1076 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1077 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1078 private Double getWforGaugeAndQ(final Gauge gauge, final double q) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1079 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1080 final String key = gauge.getName() + String.valueOf(q); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1081 if (!this.gaugeQ_W_Map.containsKey(key)) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1082 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1083 final DischargeTable dt = gauge.fetchMasterDischargeTable(); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1084 final double[][] table = DischargeTables.loadDischargeTableValues(dt); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1085 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1086 final double[] qs = DischargeTables.getWsForQ(table, q); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1087 |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1088 // final DischargeTables dct = new DischargeTables(gauge.getRiver().getName(), gauge.getName()); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1089 // final double[] qs = DischargeTables.getWsForQ(dct.getFirstTable(), q); // TODO: KLÄREN, welche Abflusstabelle |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1090 // genommen werden soll! |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1091 if (qs != null && qs.length > 0) { |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1092 this.gaugeQ_W_Map.put(key, qs[0]); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1093 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1094 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1095 return this.gaugeQ_W_Map.get(key); |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1096 } |
ce13a2f07290
pdf exports added for fixation+bundu (waterlevel)
gernotbelger
parents:
9485
diff
changeset
|
1097 |
389
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
1098 } |
69d05357c177
Added an exporter (OutGenerator) for waterlevels which currently supports CSV exports.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
1099 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 : |