annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationCalculationResult.java @ 9170:9b2e46090099

tkh cast exception fix gigantic refactoring 2
author gernotbelger
date Thu, 21 Jun 2018 14:32:11 +0200
parents 23945061daec
children 1614cb14308f
rev   line source
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
2 * Software engineering by
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
5 *
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
9 */
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.sinfo.flood_duration;
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
11
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
12 import java.text.NumberFormat;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
13 import java.util.ArrayList;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
14 import java.util.Collection;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
15 import java.util.List;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
16
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
17 import org.dive4elements.river.artifacts.common.ExportContextCSV;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
18 import org.dive4elements.river.artifacts.common.GeneralResultType;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
19 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.common.ResultRow;
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
21 import org.dive4elements.river.artifacts.sinfo.common.AbstractTkhCalculationResult;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
22 import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
23 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
24 import org.dive4elements.river.artifacts.sinfo.util.WstInfo;
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
25
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
26 /**
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
27 * Contains the results of a {@link FloodDurationCalculation}.
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
28 *
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
29 * @author Gernot Belger
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
30 */
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
31 final class FloodDurationCalculationResult extends AbstractTkhCalculationResult<FloodDurationCalculationResults> {
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
32
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
33 private static final long serialVersionUID = 1L;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
34 private final int waterlevelCount; // TODO: ggf 2 verschiedene Result-Klassen?
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
35 // private final WstInfo wstInfo;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
36 private final int maxWaterlevelPdf = 3;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
37
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
38 private enum ExportMode {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
39 pdf, csv
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
40 }
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
41
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
42 public FloodDurationCalculationResult(final String label, final WstInfo wstInfo, final Collection<ResultRow> rows, final boolean hasTkh,
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
43 final int waterlevelCount) {
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
44 super(label, wstInfo, hasTkh, rows);
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
45 this.waterlevelCount = waterlevelCount;
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
46 // this.wstInfo = wstInfo;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
47 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
48
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
49 @Override
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
50 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final FloodDurationCalculationResults results, final RiverInfo river) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
51
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
52 final Collection<String> header = new ArrayList<>(99);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
53
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
54 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
55 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.riverside));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
56 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.inundationduration));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
57 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.inundationdurationq));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
58 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.infrastructureHeight));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
59 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.infrastructuretype));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
60
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
61 // add dynamic headers
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
62 final int waterlevelCount = // results.
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
63 getWaterlevelCount();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
64 for (int i = 0; i < waterlevelCount; i++) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
65 final int naturalIndex = i + 1;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
66 final String appendIndex = new StringBuilder().append("_").append(naturalIndex).toString();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
67 final Object[] args = new Object[] { appendIndex };
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
68 // new StringBuilder().append('\u2081').toString(); // schlechter UTF-8-Support für subscript ints
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
69 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderW(), new Object[] { appendIndex, "results.getRiver().getWstUnit()" }));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
70 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderFloodDurPerYear(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
71 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderQ(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
72 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderBezeichn(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
73 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
74
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
75 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.gaugeLabel));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
76 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.location));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
77
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
78 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
79 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
80
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
81 @Override
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
82 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV, final FloodDurationCalculationResults results) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
83
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
84 exportContextCSV.writeCSVWaterlevelMetadata(super.getWst()); // -> export in super? -> TODO
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
85 exportContextCSV.writeBlankLine();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
86 // writer.writeNext(new String[] { "" }); // break line
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
87
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
88 }
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
89
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
90 @Override
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
91 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final FloodDurationCalculationResults results, final ResultRow row) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
92 // TODO Auto-generated method stub
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
93 return formatRow(exportContextCSV, results, row, ExportMode.csv);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
94 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
95
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
96 @Override
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
97 protected String[] formatPDFRow(final ExportContextCSV exportContextCSV, final FloodDurationCalculationResults results, final ResultRow row) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
98
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
99 return formatRow(exportContextCSV, results, row, ExportMode.pdf);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
100 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
101
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
102 @Override
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
103 protected String getJasperFile() {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
104 if (this.waterlevelCount <= 1)
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
105 return "/jasper/templates/sinfo.floodduration.jrxml"; // TODO 2 different result-classes?
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
106 else
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
107 return "/jasper/templates/sinfo.floodduration2.jrxml";
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
108 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
109
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
110 @Override
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
111 protected void addJRTableHeader(final ExportContextCSV exportContextCSV, final MetaAndTableJRDataSource source,
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
112 final FloodDurationCalculationResults results) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
113 /* column headings */
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
114 exportContextCSV.addJRMetadata(source, "station_header", GeneralResultType.station);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
115 exportContextCSV.addJRMetadata(source, "riverside_header", SInfoResultType.riverside);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
116 exportContextCSV.addJRMetadata(source, "inundationduration_header", SInfoResultType.inundationduration);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
117 exportContextCSV.addJRMetadata(source, "inundationduration_q_header", SInfoResultType.inundationdurationq);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
118 exportContextCSV.addJRMetadata(source, "infrastructure_height_header", SInfoResultType.infrastructureHeightFloodDur);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
119 exportContextCSV.addJRMetadata(source, "infrastructure_type_header", SInfoResultType.infrastructuretype);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
120
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
121 // add dynamic headers
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
122
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
123 if (this.waterlevelCount == 0 || this.waterlevelCount == 2) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
124 source.addMetaData("dummy", "dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
125 source.addMetaData("dummy", "dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
126 source.addMetaData("dummy", "dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
127 source.addMetaData("dummy", "dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
128 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
129
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
130 for (int i = 0; i < this.waterlevelCount; i++) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
131 final int naturalIndex = i + 1;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
132
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
133 final Object[] args = new String[] { new StringBuilder().append("_").append(naturalIndex).toString() };
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
134 exportContextCSV.addJRMetadata(source, getPdfHeader("w", naturalIndex), exportContextCSV.msg(DurationWaterlevel.getHeaderW(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
135 exportContextCSV.addJRMetadata(source, getPdfHeader("duration", naturalIndex),
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
136 exportContextCSV.msg(DurationWaterlevel.getHeaderFloodDurPerYear(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
137 exportContextCSV.addJRMetadata(source, getPdfHeader("q", naturalIndex), exportContextCSV.msg(DurationWaterlevel.getHeaderQ(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
138 exportContextCSV.addJRMetadata(source, getPdfHeader("bezeichnung", naturalIndex),
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
139 exportContextCSV.msg(DurationWaterlevel.getHeaderBezeichn(), args));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
140
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
141 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
142
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
143 exportContextCSV.addJRMetadata(source, "gauge_header", SInfoResultType.gaugeLabel);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
144 exportContextCSV.addJRMetadata(source, "location_header", SInfoResultType.location);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
145
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
146 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
147
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
148 public int getWaterlevelCount() { // der exporter muss daran, um spalten auszublenden
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
149 return this.waterlevelCount;
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
150 }
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
151
9170
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
152 private String[] formatRow(final ExportContextCSV exportContextCSV, final FloodDurationCalculationResults results, final ResultRow row,
9b2e46090099 tkh cast exception fix
gernotbelger
parents: 9150
diff changeset
153 final ExportMode mode) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
154
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
155 final Collection<String> lines = new ArrayList<>(99);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
156
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
157 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.station));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
158 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.riverside));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
159 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.inundationduration));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
160 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.inundationdurationq));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
161 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.infrastructureHeight));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
162 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.infrastructuretype));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
163
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
164 final List<DurationWaterlevel> waterlevelList = (List<DurationWaterlevel>) row.getValue(SInfoResultType.customMultiRowColWaterlevel);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
165 if (waterlevelList != null) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
166 final NumberFormat wFormatter = exportContextCSV.getFlowDepthFormatter();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
167 final NumberFormat qFormatter = exportContextCSV.getQFormatter();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
168
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
169 for (int i = 0; i < waterlevelList.size(); i++) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
170
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
171 if (i == this.maxWaterlevelPdf && mode == ExportMode.pdf)
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
172 break;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
173
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
174 final DurationWaterlevel item = waterlevelList.get(i);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
175 lines.add(item.getWFormatted(wFormatter));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
176 lines.add(item.getFloodDurDaysPerYearFormatted());
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
177 lines.add(item.getQFormatted(qFormatter));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
178 lines.add(item.getBezeichnung());
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
179 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
180 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
181
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
182 if ((this.waterlevelCount == 0 || this.waterlevelCount == 2) && mode == ExportMode.pdf) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
183 lines.add("dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
184 lines.add("dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
185 lines.add("dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
186 lines.add("dummy");
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
187 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
188
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
189 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.gaugeLabel));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
190 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.location));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
191 return lines.toArray(new String[lines.size()]);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
192 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
193
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
194 private String getPdfHeader(final String rootStr, final int index) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
195 final String hd = "_header";
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
196 final StringBuilder builder = new StringBuilder();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
197 return builder.append(rootStr).append("_").append(index).append(hd).toString();
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
198 }
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
199 }

http://dive4elements.wald.intevation.org