Mercurial > dive4elements > river
comparison 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 |
comparison
equal
deleted
inserted
replaced
9242:2ea7b61797d3 | 9243:da0bdbcd6f09 |
---|---|
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 } |