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