annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/salix/SalixLineCalculationRegionalResult.java @ 9309:9a9f076d5716

Work on U-Info salix line calculation
author mschaefer
date Wed, 25 Jul 2018 19:29:25 +0200
parents da0bdbcd6f09
children 72b3270e1568
rev   line source
9243
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
2 * Software engineering by
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
5 *
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
9 */
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.uinfo.salix;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
11
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
12 import java.text.NumberFormat;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
13 import java.util.Collection;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
14 import java.util.List;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
15
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.common.ExportContextCSV;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.common.IExportContext;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.common.ResultRow;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.sinfo.util.WstInfo;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.uinfo.commons.UInfoResultType;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
22
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
23 /**
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
24 * @author Domenico Nardi Tironi
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
25 */
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
26 final class SalixLineCalculationRegionalResult extends SalixLineCalculationNoScenarioResult {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
27
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
28 private static final long serialVersionUID = 1L;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
29
9309
9a9f076d5716 Work on U-Info salix line calculation
mschaefer
parents: 9243
diff changeset
30 public SalixLineCalculationRegionalResult(final String label, final WstInfo wst, final Collection<ResultRow> rows) {
9243
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
31 super(label, wst, rows);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
32 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
33
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
34 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
35 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
36
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
37 final Collection<String> header = super.writeNoScenarioHeader(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
38
9309
9a9f076d5716 Work on U-Info salix line calculation
mschaefer
parents: 9243
diff changeset
39 header.add(exportContextCSV.msg(SalixScenario.getScenarioValueHeader()));
9a9f076d5716 Work on U-Info salix line calculation
mschaefer
parents: 9243
diff changeset
40 header.add(exportContextCSV.msg(SalixScenario.getDwsplHeader()));
9243
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
41
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
42 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
43 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
44
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
45 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
46 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
47 writeRegionalEffectsCSVMetadata(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
48 exportContextCSV.writeBlankLine();
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
49
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
50 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
51
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
52 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
53 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
54
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
55 return formatRow(exportContextCSV, row);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
56 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
57
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
58 private String[] formatRow(final IExportContext context, final ResultRow row) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
59
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
60 final Collection<String> lines = super.getNoScenarioFormat(row, context);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
61
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
62 if (context instanceof ExportContextCSV) { // enum gespart - pdf-export hat ja nur die drei spalten
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
63 final NumberFormat formatter = ((ExportContextCSV) context).getSalixScenFormatter();
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
64 final List<SalixScenario> scenList = (List<SalixScenario>) row.getValue(UInfoResultType.customMultiRowColSalixRegionalValue_Dwspl);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
65
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
66 for (final SalixScenario scenario : scenList) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
67 // scenario unused; index wurde ja verworfen, stattdessen 2 spalten
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
68 lines.add(scenario.getSalixValueFormatted(formatter));
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
69 lines.add(scenario.getDwsplFormatted());
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
70 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
71 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
72 return lines.toArray(new String[lines.size()]);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
73 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
74
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
75 private void writeRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
76 final String main = "uinfo.export.csv.meta.header.salix.regional";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
77 // "##Regional wirkende Eingriffe"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
78 exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
79 writeRegionalCommonCSVMeta(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
80 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
81
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
82 // TODO: move to SupraRegionalEffectsResult-Class; remove here
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
83 // private void writeExtendedRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
84 // final String main = "uinfo.export.csv.meta.header.salix.regionalextended";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
85 // // "##Überregional wirkende Eingriffe"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
86 // exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
87 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
88 // writeRegionalCommonCSVMeta(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
89 // }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
90
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
91 // TODO: move to historical class and delete here
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
92 // private void writeHistoricalViewCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
93 // final String main = "uinfo.export.csv.meta.header.salix.historical";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
94 // // "##Historische Betrachtung"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
95 // exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
96 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
97 // final String mainSub = "uinfo.export.csv.meta.header.salix";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
98 // // "# Szenariotyp: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
99 // exportContextCSV.writeCSVMetaEntry(mainSub + ".szenariotyp");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
100 // // "# Teilabschnitt: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
101 // exportContextCSV.writeCSVMetaEntry(mainSub + ".teilabschnitt");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
102 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
103 // // "# Art des Zeitraums: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
104 // exportContextCSV.writeCSVMetaEntry(main + ".zeitart");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
105 // // "# Historischer Zeitpunkt: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
106 // exportContextCSV.writeCSVMetaEntry(main + ".zeitpunkt");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
107 // }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
108 }

http://dive4elements.wald.intevation.org