annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/salix/SalixLineCalculationRegionalResult.java @ 9243:da0bdbcd6f09

salix.supraRegional+Regional results
author gernotbelger
date Wed, 11 Jul 2018 13:36:18 +0200
parents
children 9a9f076d5716
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 private final int[] scenarioValues;
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
30
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
31 public SalixLineCalculationRegionalResult(final String label, final WstInfo wst, final Collection<ResultRow> rows, final int[] scenarioValues) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
32 super(label, wst, rows);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
33 this.scenarioValues = scenarioValues; // TODO: diese values müssen eigentlich nur ne anzahl sein, oder so. Ergibt sihc in der Berech
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
34 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
35
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
36 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
37 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
38
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
39 final Collection<String> header = super.writeNoScenarioHeader(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
40
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
41 for (int i = 0; i < this.scenarioValues.length; i++) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
42 // index wurde verworfen, stattdessen 2 spalten
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
43
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
44 header.add(exportContextCSV.msg(SalixScenario.getScenarioValueHeader()) + " (" + (i + 1) + ")"); // index kann auch weg, war nur ne idee
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
45 header.add(exportContextCSV.msg(SalixScenario.getDwsplHeader()) + " (" + (i + 1) + ")");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
46 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
47 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
48 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
49
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
50 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
51 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
52 writeRegionalEffectsCSVMetadata(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
53 exportContextCSV.writeBlankLine();
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
54
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
55 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
56
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
57 @Override
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
58 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
59
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
60 return formatRow(exportContextCSV, row);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
61 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
62
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
63 private String[] formatRow(final IExportContext context, final ResultRow row) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
64
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
65 final Collection<String> lines = super.getNoScenarioFormat(row, context);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
66
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
67 if (context instanceof ExportContextCSV) { // enum gespart - pdf-export hat ja nur die drei spalten
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
68 final NumberFormat formatter = ((ExportContextCSV) context).getSalixScenFormatter();
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
69 final List<SalixScenario> scenList = (List<SalixScenario>) row.getValue(UInfoResultType.customMultiRowColSalixRegionalValue_Dwspl);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
70
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
71 for (final SalixScenario scenario : scenList) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
72 // scenario unused; index wurde ja verworfen, stattdessen 2 spalten
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
73 lines.add(scenario.getSalixValueFormatted(formatter));
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
74 lines.add(scenario.getDwsplFormatted());
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
75 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
76 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
77 return lines.toArray(new String[lines.size()]);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
78 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
79
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
80 private void writeRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
81 final String main = "uinfo.export.csv.meta.header.salix.regional";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
82 // "##Regional wirkende Eingriffe"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
83 exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
84 writeRegionalCommonCSVMeta(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
85 }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
86
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
87 // TODO: move to SupraRegionalEffectsResult-Class; remove here
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
88 // private void writeExtendedRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
89 // final String main = "uinfo.export.csv.meta.header.salix.regionalextended";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
90 // // "##Überregional wirkende Eingriffe"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
91 // exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
92 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
93 // writeRegionalCommonCSVMeta(exportContextCSV);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
94 // }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
95
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
96 // TODO: move to historical class and delete here
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
97 // private void writeHistoricalViewCSVMetadata(final ExportContextCSV exportContextCSV) {
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
98 // final String main = "uinfo.export.csv.meta.header.salix.historical";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
99 // // "##Historische Betrachtung"
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
100 // exportContextCSV.writeCSVMetaEntry(main);
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
101 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
102 // final String mainSub = "uinfo.export.csv.meta.header.salix";
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
103 // // "# Szenariotyp: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
104 // exportContextCSV.writeCSVMetaEntry(mainSub + ".szenariotyp");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
105 // // "# Teilabschnitt: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
106 // exportContextCSV.writeCSVMetaEntry(mainSub + ".teilabschnitt");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
107 //
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
108 // // "# Art des Zeitraums: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
109 // exportContextCSV.writeCSVMetaEntry(main + ".zeitart");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
110 // // "# Historischer Zeitpunkt: "
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
111 // exportContextCSV.writeCSVMetaEntry(main + ".zeitpunkt");
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
112 // }
da0bdbcd6f09 salix.supraRegional+Regional results
gernotbelger
parents:
diff changeset
113 }

http://dive4elements.wald.intevation.org