annotate artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstMissVolCalculationResult2.java @ 9444:ecadc9ed0ba0

Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
author mschaefer
date Tue, 21 Aug 2018 13:41:18 +0200
parents d194c5b24bf8
children e60584f2a531
rev   line source
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
9331
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 */
9332
c64de8cc4e97 bundu.bezugswst missing volume calcResult3
gernotbelger
parents: 9331
diff changeset
31 final class BezugswstMissVolCalculationResult2 extends AbstractCalculationExportableResult implements BunduWstExporter.MissResultType {
9331
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";
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
36 private static final String fieldVolumeMsgKey = "bundu.export.bezugswst.csv.meta.miss.volume.field";
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
37 private static final String fieldMassMsgKey = "bundu.export.bezugswst.csv.meta.miss.mass.field";
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
38 private static final int fieldSize = 10;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
39
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
40 public BezugswstMissVolCalculationResult2(final String label, final Collection<ResultRow> rows) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
41 super(label, rows);
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
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
45 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
46 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
47 // no metadata
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
48 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
49
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
50 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
51 protected String getJasperFile() {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
52 return JASPER_FILE;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
53 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
54
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
55 protected String[] formatRow(final AbstractExportContext exportContext, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
56
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
57 final Collection<String> lines = new ArrayList<>(20);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
58
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
59 lines.add(exportContext.formatRowValue(row, GeneralResultType.station));
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
60 final List<String> vFields = (List<String>) row.getValue(BunduResultType.missVolumeFields);
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
61 assert (vFields.size() == fieldSize); // immer abgleichen mit der Calculation!
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
62 final List<String> mFields = (List<String>) row.getValue(BunduResultType.missMassFields);
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
63 for (int i = 0; i <= vFields.size() - 1; i++) {
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
64 lines.add(vFields.get(i));
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
65 lines.add(mFields.get(i));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
66 }
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
67 lines.add(exportContext.formatRowValue(row, BunduResultType.missVolumeMeanBed));
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
68 lines.add(exportContext.formatRowValue(row, BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
69
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
70 return lines.toArray(new String[lines.size()]);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
71 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
72
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
73 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
74 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
75
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
76 final int colSize = 2 * fieldSize + 2;
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
77 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
78 final Collection<String> header = new ArrayList<>(colSize);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
79
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
80 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
81
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
82 for (int i = 1; i <= fieldSize; i++) {
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
83 header.add(exportContextCSV.msg(fieldVolumeMsgKey, i));
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
84 header.add(exportContextCSV.msg(fieldMassMsgKey, i));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
85 }
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
86 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missVolumeMeanBed));
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
87 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
88
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
89 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
90
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[] formatCSVRow(final ExportContextCSV exportContextCSV, 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(exportContextCSV, 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 String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
101
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
102 return this.formatRow(exportContextPDF, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
103 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
104
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
105 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
106 protected void addJRTableHeader(final ExportContextPDF exportContextPDF, final MetaAndTableJRDataSource source) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
107 /* column headings */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
108
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
109 exportContextPDF.addJRMetadata(source, "station_header", GeneralResultType.station);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
110 for (int i = 1; i <= fieldSize; i++) {
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
111 exportContextPDF.addJRMetadata(source, "field_header" + String.valueOf(i), exportContextPDF.msg(fieldVolumeMsgKey, i));
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
112 exportContextPDF.addJRMetadata(source, "field_header" + String.valueOf(i), exportContextPDF.msg(fieldMassMsgKey, i));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
113 }
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
114 exportContextPDF.addJRMetadata(source, "mean_bedheight_header", BunduResultType.missVolumeMeanBed);
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
115 exportContextPDF.addJRMetadata(source, "mean_bedheight_header", BunduResultType.missMassMeanBed);
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
116
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
117 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
118 }

http://dive4elements.wald.intevation.org