annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flowdepthdev/FlowDepthDevelopmentExporter.java @ 8951:322b0e6298ea

Work on SINFO FlowDepth-Development
author gernotbelger
date Fri, 16 Mar 2018 18:08:38 +0100
parents
children c40db8e8dcae
rev   line source
8951
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
2 * Software engineering by Intevation GmbH
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
3 *
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
7 */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
8
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
9 package org.dive4elements.river.artifacts.sinfo.flowdepthdev;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
10
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
11 import java.util.ArrayList;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
12 import java.util.Collection;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
13
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
14 import org.apache.log4j.Logger;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
15 import org.dive4elements.river.artifacts.sinfo.common.AbstractSInfoExporter;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.sinfo.common.SInfoResultRow;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.sinfo.util.MetaAndTableJRDataSource;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
20
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
21 import au.com.bytecode.opencsv.CSVWriter;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
22
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
23 /**
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
24 * Generates different output formats (csv, pdf) of data that resulted from a flow depths computation.
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
25 *
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
26 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
27 * @author Gernot Belger
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
28 */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
29 // REMARK: must be public because its registered in generators.xml
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
30 public class FlowDepthDevelopmentExporter extends AbstractSInfoExporter<FlowDepthDevelopmentCalculationResult, FlowDepthDevelopmentCalculationResults> {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
31
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
32 /** The log used in this exporter. */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
33 private static Logger log = Logger.getLogger(FlowDepthDevelopmentExporter.class);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
34
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
35 private static final String JASPER_FILE = "/jasper/sinfo.flowdepthminmax.jasper";
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
36
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
37 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
38 protected Logger getLog() {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
39 return log;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
40 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
41
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
42 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
43 protected void writeCSVResultMetadata(final CSVWriter writer, final FlowDepthDevelopmentCalculationResults results,
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
44 final FlowDepthDevelopmentCalculationResult result) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
45
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
46 // FIXME: distinguish header labels
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
47 writeCSVSoundingMetadata(writer, result.getCurrentSounding());
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
48 writeCSVWaterlevelMetadata(writer, result.getCurrentWst());
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
49
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
50 // FIXME: distinguish header labels
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
51 writeCSVSoundingMetadata(writer, result.getHistoricalSounding());
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
52 writeCSVWaterlevelMetadata(writer, result.getHistoricalWst());
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
53 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
54
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
55 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
56 protected void writeCSVGlobalMetadata(final CSVWriter writer, final FlowDepthDevelopmentCalculationResults results) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
57
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
58 super.writeCSVGlobalMetadataDefaults(writer, results);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
59
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
60 writer.writeNext(new String[] { "" });
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
61 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
62
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
63 /**
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
64 * Write the header, with different headings depending on whether at a
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
65 * gauge or at a location.
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
66 *
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
67 * @param river
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
68 * @param useTkh
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
69 */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
70 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
71 protected void writeCSVHeader(final CSVWriter writer, final FlowDepthDevelopmentCalculationResults results, final RiverInfo river) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
72 log.info("FlowDepthExporter.writeCSVHeader");
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
73
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
74 final Collection<String> header = new ArrayList<>(11);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
75
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
76 header.add(msg(SInfoResultType.station.getCsvHeader()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
77 header.add(msgUnit(SInfoResultType.flowdepthDevelopment.getCsvHeader(), SInfoResultType.flowdepthDevelopment.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
78 header.add(msgUnit(SInfoResultType.flowdepthDevelopmentPerYear.getCsvHeader(), SInfoResultType.flowdepthDevelopmentPerYear.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
79
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
80 // FIXME: add data-labels in header
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
81 header.add(msgUnit(SInfoResultType.waterlevelDifference.getCsvHeader(), SInfoResultType.waterlevelDifference.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
82 header.add(msgUnit(SInfoResultType.bedHeightDifference.getCsvHeader(), SInfoResultType.bedHeightDifference.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
83
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
84 header.add(msgUnit(SInfoResultType.flowdepthCurrent.getCsvHeader(), SInfoResultType.flowdepthCurrent.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
85 header.add(msgUnit(SInfoResultType.flowdepthHistorical.getCsvHeader(), SInfoResultType.flowdepthHistorical.getUnit()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
86
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
87 header.add(msg(SInfoResultType.location.getCsvHeader()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
88
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
89 writer.writeNext(header.toArray(new String[header.size()]));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
90 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
91
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
92 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
93 protected String[] formatCSVRow(final FlowDepthDevelopmentCalculationResults results, final FlowDepthDevelopmentCalculationResult result,
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
94 final SInfoResultRow row) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
95 return formatRow(result, row);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
96 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
97
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
98 /**
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
99 * Format a row of a flow depth result into an array of string, both used by csv and pdf
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
100 *
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
101 * @param result
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
102 *
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
103 * @param useTkh
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
104 */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
105 private String[] formatRow(final FlowDepthDevelopmentCalculationResult result, final SInfoResultRow row) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
106
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
107 final Collection<String> lines = new ArrayList<>(10);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
108
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
109 lines.add(row.exportValue(this.context, SInfoResultType.station));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
110
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
111 // FIXME
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
112
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
113 // REMARK: null check as pdf will call this with null and in that case we show all columns (to avoid multiple jasper
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
114 // FIXME: does not work like this: we may have several pairs of min/max; so we need to look at all of them?
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
115 // templates)
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
116 // if (result == null || result.getMinSounding() != null)
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
117 lines.add(row.exportValue(this.context, SInfoResultType.flowdepthmin));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
118 // if (result == null || result.getMaxSounding() != null)
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
119 lines.add(row.exportValue(this.context, SInfoResultType.flowdepthmax));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
120
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
121 lines.add(row.exportValue(this.context, SInfoResultType.waterlevel));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
122 lines.add(row.exportValue(this.context, SInfoResultType.discharge));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
123 lines.add(row.exportValue(this.context, SInfoResultType.waterlevelLabel));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
124 lines.add(row.exportValue(this.context, SInfoResultType.gaugeLabel));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
125 lines.add(row.exportValue(this.context, SInfoResultType.meanBedHeight));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
126 lines.add(row.exportValue(this.context, SInfoResultType.soundingLabel));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
127 lines.add(row.exportValue(this.context, SInfoResultType.location));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
128
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
129 return lines.toArray(new String[lines.size()]);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
130 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
131
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
132 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
133 protected final String getJasperFile() {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
134 return JASPER_FILE;
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
135 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
136
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
137 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
138 protected final void addJRMetaData(final MetaAndTableJRDataSource source, final FlowDepthDevelopmentCalculationResults results) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
139
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
140 /* general metadata */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
141 super.addJRMetaDataDefaults(source, results);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
142
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
143 /* column headings */
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
144 // FIXME
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
145 source.addMetaData("station_header", SInfoResultType.station.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
146 source.addMetaData("flowdepthmin_header", SInfoResultType.flowdepthmin.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
147 source.addMetaData("flowdepthmax_header", SInfoResultType.flowdepthmax.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
148 source.addMetaData("waterlevel_header", SInfoResultType.waterlevel.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
149 source.addMetaData("discharge_header", SInfoResultType.discharge.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
150 source.addMetaData("waterlevel_name_header", SInfoResultType.waterlevelLabel.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
151 source.addMetaData("gauge_header", SInfoResultType.gaugeLabel.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
152 source.addMetaData("bedheight_header", SInfoResultType.meanBedHeight.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
153 source.addMetaData("sounding_name_header", SInfoResultType.soundingLabel.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
154 source.addMetaData("location_header", SInfoResultType.location.getPdfHeader(this.context.getMeta()));
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
155 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
156
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
157 @Override
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
158 protected String[] formatPDFRow(final FlowDepthDevelopmentCalculationResults results, final SInfoResultRow row) {
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
159 return formatRow(null, row);
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
160 }
322b0e6298ea Work on SINFO FlowDepth-Development
gernotbelger
parents:
diff changeset
161 }

http://dive4elements.wald.intevation.org