annotate artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstMissVolCalculationResult2.java @ 9331:127638669052

bundu bezugswst result 2
author gernotbelger
date Fri, 27 Jul 2018 18:49:55 +0200
parents
children c64de8cc4e97
rev   line source
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
2 * Software engineering by
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
5 *
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
9 */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.bundu.bezugswst;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
11
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
12 import java.util.ArrayList;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
13 import java.util.Collection;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
14 import java.util.List;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
15
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.bundu.BunduResultType;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.common.AbstractExportContext;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.common.ExportContextCSV;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.common.ExportContextPDF;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.common.GeneralResultType;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
22 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
23 import org.dive4elements.river.artifacts.common.ResultRow;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
24 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
25
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
26 /**
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
27 * Contains the results of a //TODO LINK{@link BezugswstCalculation}.
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
28 *
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
29 * @author Gernot Belger
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
30 */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
31 final class BezugswstMissVolCalculationResult2 extends AbstractCalculationExportableResult {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
32
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
33 private static final long serialVersionUID = 1L;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
34
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
35 private static final String JASPER_FILE = "/jasper/templates/bundu.bezugswst.result2.jrxml";
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
36 private static final String fieldMsgStr = "bundu.export.bezugswst.csv.meta.miss.field";
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
37 private static final int fieldSize = 10;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
38
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
39 public BezugswstMissVolCalculationResult2(final String label, final Collection<ResultRow> rows) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
40 super(label, rows);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
41
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
42 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
43
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
44 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
45 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
46 // no metadata
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
47 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
48
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
49 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
50 protected String getJasperFile() {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
51 return JASPER_FILE;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
52 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
53
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
54 protected String[] formatRow(final AbstractExportContext exportContext, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
55
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
56 final Collection<String> lines = new ArrayList<>(20);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
57
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
58 lines.add(exportContext.formatRowValue(row, GeneralResultType.station));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
59 final List<String> fields = (List<String>) row.getValue(BunduResultType.fields);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
60 assert (fields.size() == fieldSize); // immer abgleichen mit der Calculation!
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
61 for (final String field : fields) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
62 lines.add(field);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
63 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
64 lines.add(exportContext.formatRowValue(row, BunduResultType.meanBedheight));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
65
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
66 return lines.toArray(new String[lines.size()]);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
67 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
68
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
69 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
70 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
71
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
72 final int colSize = 15;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
73 exportContextCSV.writeTitleForTabs("bundu.export.csv.title.bezugswst.result2", colSize); // Voraussetzung für Tabs ist, dass der Titel vor den Headern
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
74 final Collection<String> header = new ArrayList<>(colSize);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
75
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
76 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
77
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
78 for (int i = 1; i <= fieldSize; i++) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
79 header.add(exportContextCSV.msg(fieldMsgStr, i));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
80 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
81 header.add(exportContextCSV.formatCsvHeader(BunduResultType.meanBedheight));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
82
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
83 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
84
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
85 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
86
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
87 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
88 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
89
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
90 return this.formatRow(exportContextCSV, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
91 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
92
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
93 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
94 protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
95
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
96 return this.formatRow(exportContextPDF, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
97 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
98
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
99 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
100 protected void addJRTableHeader(final ExportContextPDF exportContextPDF, final MetaAndTableJRDataSource source) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
101 /* column headings */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
102
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
103 exportContextPDF.addJRMetadata(source, "station_header", GeneralResultType.station);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
104 for (int i = 1; i <= fieldSize; i++) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
105 exportContextPDF.addJRMetadata(source, "field_header" + String.valueOf(i), exportContextPDF.msg(fieldMsgStr, i));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
106 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
107 exportContextPDF.addJRMetadata(source, "mean_bedheight_header", BunduResultType.meanBedheight);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
108
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
109 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
110 }

http://dive4elements.wald.intevation.org