annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/collision/CollisionCalcOverviewResult.java @ 9204:4f411c6ee3ae

Individual facets/themes for single years i the S-Info collisions output
author mschaefer
date Mon, 02 Jul 2018 17:40:39 +0200
parents a4121ec450d6
children 3dae6b78e1da
rev   line source
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
2 * Software engineering by
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
5 *
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
9 */
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.sinfo.collision;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
11
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
12 import java.util.ArrayList;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
13 import java.util.Collection;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
14
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
15 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.common.ExportContextCSV;
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
17 import org.dive4elements.river.artifacts.common.ExportContextPDF;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.common.GeneralResultType;
9204
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
19 import org.dive4elements.river.artifacts.common.IResultType;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.common.ResultRow;
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
22 import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
23 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
24
9204
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
25 import gnu.trove.TDoubleArrayList;
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
26
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
27 /**
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
28 * Contains the results of a {@link CollisionCalculation}.
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
29 *
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
30 * @author Gernot Belger
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
31 */
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
32 final public class CollisionCalcOverviewResult extends AbstractCalculationExportableResult {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
33
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
34 private static final long serialVersionUID = 1L;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
35
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
36 private static final String JASPER_FILE = "/jasper/templates/sinfo.collision.overview.jrxml";
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
37
9204
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
38 private final int[] singleYears;
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
39
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
40 public CollisionCalcOverviewResult(final String label, final int[] singleYears, final Collection<ResultRow> rows) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
41 super(label, rows);
9204
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
42 this.singleYears = singleYears;
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
43 }
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
44
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
45 public int[] getSingleYears() {
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
46 return this.singleYears;
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
47 }
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
48
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
49 @Override
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
50 public double[][] getStationPoints(final IResultType type, final int index) {
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
51
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
52 final TDoubleArrayList xPoints = new TDoubleArrayList(this.rows.size());
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
53 final TDoubleArrayList yPoints = new TDoubleArrayList(this.rows.size());
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
54
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
55 for (final ResultRow row : this.rows) {
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
56
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
57 if ((this.singleYears == null) || (Integer.valueOf(row.getValue(SInfoResultType.years).toString()) == this.singleYears[index])) {
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
58
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
59 final double station = row.getDoubleValue(GeneralResultType.station);
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
60 final double value = row.getDoubleValue(type);
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
61
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
62 xPoints.add(station);
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
63 yPoints.add(value);
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
64 }
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
65 }
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
66
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
67 return new double[][] { xPoints.toNativeArray(), yPoints.toNativeArray() };
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
68 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
69
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
70 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
71 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
9172
3ace6db2f87b collision details+pdf-export
gernotbelger
parents: 9171
diff changeset
72 // do nothing so far
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
73 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
74
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
75 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
76 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
9171
f1be005f0c46 tab titles from server
gernotbelger
parents: 9157
diff changeset
77 final int colSize = 3;
f1be005f0c46 tab titles from server
gernotbelger
parents: 9157
diff changeset
78 exportContextCSV.writeTitleForTabs("sinfo.export.csv.title.collison.overview", 3); // Voraussetzung für Tabs ist, dass der Titel vor den Headern
9204
4f411c6ee3ae Individual facets/themes for single years i the S-Info collisions output
mschaefer
parents: 9195
diff changeset
79 // geschrieben wird.
9171
f1be005f0c46 tab titles from server
gernotbelger
parents: 9157
diff changeset
80 // Das ist etwas doof.
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
81
9171
f1be005f0c46 tab titles from server
gernotbelger
parents: 9157
diff changeset
82 final Collection<String> header = new ArrayList<>(colSize);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
83
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
84 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
85 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.years));
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
86 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.collisionCount));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
87
9171
f1be005f0c46 tab titles from server
gernotbelger
parents: 9157
diff changeset
88 exportContextCSV.writeCSVLine(header.toArray(new String[colSize]));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
89 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
90
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
91 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
92 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
93 return formatRow(exportContextCSV, row);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
94 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
95
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
96 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
97 protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
98
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
99 final Collection<String> lines = new ArrayList<>(3);
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
100
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
101 lines.add(exportContextPDF.formatRowValue(row, GeneralResultType.station));
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
102 lines.add(exportContextPDF.formatRowValue(row, SInfoResultType.years));
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
103 lines.add(exportContextPDF.formatRowValue(row, SInfoResultType.collisionCount));
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
104
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
105 return lines.toArray(new String[lines.size()]);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
106 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
107
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
108 private String[] formatRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
109
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
110 final Collection<String> lines = new ArrayList<>(3);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
111
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
112 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.station));
9157
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
113 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.years));
f9bb5d0a6ff3 Added the S-Info collision calculation and chart output
mschaefer
parents: 9150
diff changeset
114 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.collisionCount));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
115
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
116 return lines.toArray(new String[lines.size()]);
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
117 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
118
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
119 @Override
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
120 protected String getJasperFile() {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
121 return JASPER_FILE;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
122 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
123
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
124 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
125 protected void addJRTableHeader(final ExportContextPDF exportContext, final MetaAndTableJRDataSource source) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
126
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
127 /* column headings */
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
128 exportContext.addJRMetadata(source, "station_header", GeneralResultType.station);
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
129 exportContext.addJRMetadata(source, "collision_years_header", SInfoResultType.years);
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9172
diff changeset
130 exportContext.addJRMetadata(source, "collision_count_header", SInfoResultType.collisionCount);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
131 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents:
diff changeset
132 }

http://dive4elements.wald.intevation.org