Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/fixings/FixATExport.java @ 5994:af13ceeba52a
Removed trailing whitespace.
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Sun, 12 May 2013 18:13:50 +0200 |
parents | 59ff03ff48f1 |
children | a0078e5e3b39 |
rev | line source |
---|---|
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
2 * Software engineering by Intevation GmbH |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
3 * |
5994
af13ceeba52a
Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5867
diff
changeset
|
4 * This file is Free Software under the GNU AGPL (>=v3) |
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the |
5994
af13ceeba52a
Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5867
diff
changeset
|
6 * documentation coming with Dive4Elements River for details. |
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
7 */ |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
8 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
9 package org.dive4elements.river.exports.fixings; |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
10 |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
11 import au.com.bytecode.opencsv.CSVWriter; |
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
12 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
13 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
14 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
15 import org.dive4elements.river.artifacts.D4EArtifact; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
16 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
17 import org.dive4elements.river.artifacts.access.FixAccess; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
18 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
19 import org.dive4elements.river.artifacts.math.fitting.Function; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
20 import org.dive4elements.river.artifacts.math.fitting.FunctionFactory; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
21 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
22 import org.dive4elements.river.artifacts.model.CalculationResult; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
23 import org.dive4elements.river.artifacts.model.Parameters; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
24 |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
25 import org.dive4elements.river.artifacts.model.fixings.FixResult; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
26 |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5148
diff
changeset
|
27 import org.dive4elements.river.exports.AbstractExporter; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
28 |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
29 import java.io.IOException; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
30 import java.io.OutputStream; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
31 import java.io.OutputStreamWriter; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
32 import java.io.Writer; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
33 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
34 import org.apache.log4j.Logger; |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
35 |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
36 import org.w3c.dom.Document; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
37 import org.w3c.dom.NodeList; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
38 |
3650
cbe2febe30cc
Merged revisions 5391-5392 via svnmerge from
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
3601
diff
changeset
|
39 /** Export result of fixation analysis. */ |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
40 public class FixATExport extends AbstractExporter { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
41 |
3650
cbe2febe30cc
Merged revisions 5391-5392 via svnmerge from
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
3601
diff
changeset
|
42 /** Private logger. */ |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
43 private static Logger logger = |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
44 Logger.getLogger(FixATExport.class); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
45 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
46 protected Function function; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
47 protected Parameters parameters; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
48 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
49 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
50 @Override |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
51 public void doOut(ArtifactAndFacet bundle, Document attr, boolean visible) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
52 logger.debug("AT Export doOut()."); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
53 Object data = bundle.getData(context); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
54 if (data instanceof CalculationResult) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
55 CalculationResult cr = (CalculationResult)data; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
56 Object resData = cr.getData(); |
5055
3b974a24a8e1
Fixed AT-Export in 'ausgel. WSPL'.
Raimund Renkert <rrenkert@intevation.de>
parents:
4949
diff
changeset
|
57 if (resData instanceof FixResult) { |
3b974a24a8e1
Fixed AT-Export in 'ausgel. WSPL'.
Raimund Renkert <rrenkert@intevation.de>
parents:
4949
diff
changeset
|
58 this.parameters = ((FixResult)resData).getParameters(); |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
59 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
60 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
61 else { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
62 logger.debug("No CalculationResult found for AT export."); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
63 return; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
64 } |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
65 FixAccess access = new FixAccess((D4EArtifact)this.master, context); |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
66 String f = access.getFunction(); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
67 if (f == null || f.length() == 0) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
68 logger.debug("No function found for AT export."); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
69 return; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
70 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
71 this.function = FunctionFactory.getInstance().getFunction(f); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
72 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
73 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
74 @Override |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
75 public void generate() throws IOException { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
76 if (this.function == null || this.parameters == null) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
77 logger.debug("No function or paramters for AT export."); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
78 return; |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
79 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
80 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
81 Writer writer = new OutputStreamWriter(out, DEFAULT_CSV_CHARSET); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
82 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
83 FixAccess access = new FixAccess((D4EArtifact)this.master, context); |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
84 FixATWriter atWriter = new FixATWriter(this.function, this.parameters); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
85 NodeList nodes = request.getElementsByTagName("km"); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
86 String km = nodes.item(0).getTextContent(); |
3601
6c94153cc4a4
Removed superfluous import. s/Double.valueOf/Double.parseDouble/
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents:
3600
diff
changeset
|
87 double dkm = Double.parseDouble(km); |
4866
acfd48384835
Changed data field names in fix analsis to ld_from, ld_to, ld step.
Raimund Renkert <rrenkert@intevation.de>
parents:
3650
diff
changeset
|
88 String river = access.getRiver(); |
3599
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
89 atWriter.write(writer, context.getMeta(), river, dkm); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
90 writer.close(); |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
91 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
92 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
93 @Override |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
94 protected void writeCSVData(CSVWriter writer) throws IOException { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
95 // The concrete writer is used to write csv data. |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
96 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
97 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
98 @Override |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
99 protected void writePDF(OutputStream out) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
100 // Implement me! |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
101 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
102 |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
103 @Override |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
104 protected void addData(Object data) { |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
105 // Nothing to do here. |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
106 } |
659c1111db13
FixA: Added exporter for AT files.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
107 } |
3650
cbe2febe30cc
Merged revisions 5391-5392 via svnmerge from
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
3601
diff
changeset
|
108 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 : |