9150
|
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.sinfo.collision; |
|
11 |
|
12 import java.util.ArrayList; |
|
13 import java.util.Collection; |
|
14 |
|
15 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult; |
|
16 import org.dive4elements.river.artifacts.common.ExportContextCSV; |
|
17 import org.dive4elements.river.artifacts.common.GeneralResultType; |
|
18 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource; |
|
19 import org.dive4elements.river.artifacts.common.ResultRow; |
|
20 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; |
|
21 |
|
22 /** |
|
23 * Contains the results of a {@link FloodDurationCalculation}. |
|
24 * |
|
25 * @author Gernot Belger |
|
26 */ |
|
27 final class CollisionCalcOverviewResult extends AbstractCalculationExportableResult<CollisionCalculationResults> { |
|
28 |
|
29 private static final long serialVersionUID = 1L; |
|
30 |
|
31 private static final String JASPER_FILE = "/jasper/templates/sinfo.collision.overview.jrxml"; |
|
32 |
|
33 public CollisionCalcOverviewResult(final String label, final Collection<ResultRow> rows) { |
|
34 super(label, rows); |
|
35 } |
|
36 |
|
37 @Override |
|
38 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results) { |
|
39 // TODO Auto-generated method stub |
|
40 // final WstInfo wst = result.getWst(); |
|
41 // exportContext.writeCSVWaterlevelMetadata(writer, wst); |
|
42 } |
|
43 |
|
44 @Override |
|
45 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final RiverInfo river) { |
|
46 |
|
47 // FIXME wrong columns: |
|
48 final Collection<String> header = new ArrayList<>(99); |
|
49 |
|
50 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station)); |
|
51 // |
|
52 // header.add(exportContext.formatCsvHeader(SInfoResultType.riverside)); |
|
53 // header.add(exportContext.formatCsvHeader(SInfoResultType.inundationduration)); |
|
54 // header.add(exportContext.formatCsvHeader(SInfoResultType.inundationdurationq)); |
|
55 // header.add(exportContext.formatCsvHeader(SInfoResultType.infrastructureHeight)); |
|
56 // header.add(exportContext.formatCsvHeader(SInfoResultType.infrastructuretype)); |
|
57 // header.add(exportContext.formatCsvHeader(SInfoResultType.gaugeLabel)); |
|
58 // header.add(exportContext.formatCsvHeader(SInfoResultType.location)); |
|
59 |
|
60 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()])); |
|
61 } |
|
62 |
|
63 @Override |
|
64 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) { |
|
65 return formatRow(exportContextCSV, results, row); |
|
66 } |
|
67 |
|
68 @Override |
|
69 protected String[] formatPDFRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) { |
|
70 return formatRow(exportContextCSV, results, row); |
|
71 } |
|
72 |
|
73 private String[] formatRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) { |
|
74 |
|
75 final Collection<String> lines = new ArrayList<>(11); |
|
76 |
|
77 // FIXME wrong columns: |
|
78 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.station)); |
|
79 // lines.add(exportContext.formatRowValue(row, SInfoResultType.tkh)); |
|
80 // lines.add(exportContext.formatRowValue(row, SInfoResultType.soilkind)); |
|
81 // lines.add(exportContext.formatRowValue(row, SInfoResultType.meanBedHeight)); |
|
82 // lines.add(exportContext.formatRowValue(row, SInfoResultType.waterlevel)); |
|
83 // lines.add(exportContext.formatRowValue(row, SInfoResultType.discharge)); |
|
84 // lines.add(exportContext.formatRowValue(row, SInfoResultType.gaugeLabel)); |
|
85 // lines.add(exportContext.formatRowValue(row, SInfoResultType.location)); |
|
86 |
|
87 return lines.toArray(new String[lines.size()]); |
|
88 } |
|
89 |
|
90 @Override |
|
91 protected String getJasperFile() { |
|
92 return JASPER_FILE; |
|
93 } |
|
94 |
|
95 @Override |
|
96 protected void addJRTableHeader(final ExportContextCSV exportContextCSV, final MetaAndTableJRDataSource source, final CollisionCalculationResults results) { |
|
97 |
|
98 /* column headings */ |
|
99 // FIXME wrong columns: |
|
100 exportContextCSV.addJRMetadata(source, "station_header", GeneralResultType.station); |
|
101 // exportContext.addJRMetadata(source, "station_header", GeneralResultType.station); |
|
102 // exportContext.addJRMetadata(source, "tkh_header", SInfoResultType.tkh); |
|
103 // exportContext.addJRMetadata(source, "tkhkind_header", SInfoResultType.soilkind); |
|
104 // exportContext.addJRMetadata(source, "bedheight_header", SInfoResultType.meanBedHeight); |
|
105 // exportContext.addJRMetadata(source, "waterlevel_header", SInfoResultType.waterlevel); |
|
106 // exportContext.addJRMetadata(source, "discharge_header", SInfoResultType.discharge); |
|
107 } |
|
108 } |