annotate artifacts/src/main/java/org/dive4elements/river/exports/minfo/BedDifferenceExporter.java @ 6217:e213b538f78c

Added exporter for bed height differences.
author Raimund Renkert <rrenkert@intevation.de>
date Thu, 06 Jun 2013 16:41:27 +0200
parents
children 34f393434913
rev   line source
6217
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
1 package org.dive4elements.river.exports.minfo;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
2
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
3 import gnu.trove.TDoubleArrayList;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
4
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
5 import java.io.IOException;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
6 import java.io.OutputStream;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
7 import java.text.NumberFormat;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
8 import java.util.LinkedList;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
9 import java.util.List;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
10
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
11 import org.apache.log4j.Logger;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
12 import org.dive4elements.artifacts.CallContext;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
13 import org.dive4elements.river.artifacts.model.CalculationResult;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 import org.dive4elements.river.artifacts.model.minfo.BedDifferencesResult;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 import org.dive4elements.river.exports.AbstractExporter;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
16 import org.dive4elements.river.utils.Formatter;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17 import org.w3c.dom.Document;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 import au.com.bytecode.opencsv.CSVWriter;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
20
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
21
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
22 public class BedDifferenceExporter
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
23 extends AbstractExporter
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
24 {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
25
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
26 /** Private logger. */
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
27 private static Logger logger =
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28 Logger.getLogger(BedDifferenceExporter.class);
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
29
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
30 private static final String CSV_HEADER_KM = "export.minfo.beddifference.km";
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
31 private static final String CSV_HEADER_DIFF =
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
32 "export.minfo.beddifference.diff";
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
33
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34 private BedDifferencesResult[] results;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
36 @Override
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
37 public void init(Document request, OutputStream out, CallContext context) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
38 logger.debug("BedQualityExporter.init");
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
39 super.init(request, out, context);
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
40 results = new BedDifferencesResult[0];
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
41 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
42 @Override
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
43 protected void writeCSVData(CSVWriter writer) throws IOException {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
44 writeCSVHeader(writer);
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
45
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
46 NumberFormat kmf = Formatter.getCalculationKm(context.getMeta());
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
47 NumberFormat mf = Formatter.getMeterFormat(context);
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
48 for (int i = 0; i < results.length; i++) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
49 BedDifferencesResult result = results[i];
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
50 double[][] kms = result.getDifferencesData();
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
51 for (int j = 0; j < kms[0].length; j++) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
52 writer.writeNext(new String[] {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
53 kmf.format(kms[0][j]), mf.format(kms[1][j])});
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
54 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
55 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
56 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
58 @Override
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
59 protected void writePDF(OutputStream out) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
60 // TODO implement me!
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
61
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
62 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
63
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
64 @Override
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
65 protected void addData(Object data) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
66 if (!(data instanceof CalculationResult)) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
67 logger.warn("Invalid data type.");
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
68 return;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
69 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
70 Object[] d = (Object[])((CalculationResult)data).getData();
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
71
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
72 if (!(d instanceof BedDifferencesResult[])) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
73 logger.warn("Invalid result object.");
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
74 return;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
75 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
76 results = (BedDifferencesResult[])d;
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
77 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
78
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
79 protected void writeCSVHeader(CSVWriter writer) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
80 logger.debug("writeCSVHeader()");
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
81
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
82 List<String> header = new LinkedList<String>();
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
83 if (results != null) {
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
84 header.add(msg(CSV_HEADER_KM, "km"));
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
85 header.add(msg(CSV_HEADER_DIFF, "m"));
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
86 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
87 writer.writeNext(header.toArray(new String[header.size()]));
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
88 }
e213b538f78c Added exporter for bed height differences.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
89 }

http://dive4elements.wald.intevation.org