Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/MiddleBedHeightExporter.java @ 8225:724081af301c
Pass request document to the context injectors.
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Mon, 08 Sep 2014 16:14:43 +0200 |
parents | e4606eae8ea5 |
children | d81c4b0d5ca7 |
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:
4929
diff
changeset
|
9 package org.dive4elements.river.exports; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
10 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
11 import java.io.OutputStream; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
12 import java.text.NumberFormat; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
13 import java.util.ArrayList; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
14 import java.util.List; |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
15 import java.util.Collections; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
16 import java.util.SortedMap; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
17 import java.util.TreeMap; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
18 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
19 import org.apache.log4j.Logger; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
20 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
21 import au.com.bytecode.opencsv.CSVWriter; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
22 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
23 import org.dive4elements.river.artifacts.D4EArtifact; |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4929
diff
changeset
|
24 import org.dive4elements.river.artifacts.model.CalculationResult; |
7983
62befca02480
Moved MiddleBedHeight classes to minfo package. Facet now returns double[][] data.
Raimund Renkert <rrenkert@intevation.de>
parents:
7693
diff
changeset
|
25 import org.dive4elements.river.artifacts.model.minfo.MiddleBedHeightData; |
7600
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
26 |
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
27 import org.dive4elements.river.model.River; |
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
28 |
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
29 import org.dive4elements.river.utils.Formatter; |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
30 import org.dive4elements.river.utils.RiverUtils; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
31 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
32 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
33 /** |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
34 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
35 */ |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
36 public class MiddleBedHeightExporter extends AbstractExporter { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
37 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
38 /** Private log. */ |
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
39 private static final Logger log = |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
40 Logger.getLogger(MiddleBedHeightExporter.class); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
41 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
42 public static final String CSV_KM = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
43 "export.bedheight_middle.csv.header.km"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
44 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
45 public static final String CSV_SOUNDING = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
46 "export.bedheight_middle.csv.header.sounding"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
47 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
48 public static final String CSV_HEIGHT = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
49 "export.bedheight_middle.csv.header.height"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
50 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
51 public static final String CSV_UNCERTAINTY = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
52 "export.bedheight_middle.csv.header.uncertainty"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
53 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
54 public static final String CSV_DATA_GAP = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
55 "export.bedheight_middle.csv.header.datagap"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
56 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
57 public static final String CSV_SOUNDING_WIDTH = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
58 "export.bedheight_middle.csv.header.soundingwidth"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
59 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
60 public static final String CSV_WIDTH = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
61 "export.bedheight_middle.csv.header.width"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
62 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
63 public static final String CSV_LOCATIONS = |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
64 "export.bedheight_middle.csv.header.locations"; |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
65 |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
66 public static final String CSV_META_YEAR = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
67 "export.bedheight_middle.csv.header.year"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
68 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
69 public static final String CSV_META_TYPE = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
70 "export.bedheight_middle.csv.header.type"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
71 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
72 public static final String CSV_META_CUR_ELEV_MODEL = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
73 "export.bedheight_middle.csv.header.cur.elevation"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
74 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
75 public static final String CSV_META_OLD_ELEV_MODEL = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
76 "export.bedheight_middle.csv.header.old.elevation"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
77 |
7999
3bdb9f99b4a0
Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7994
diff
changeset
|
78 public static final String CSV_META_RIVER_ELEV_MODEL = |
3bdb9f99b4a0
Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7994
diff
changeset
|
79 "export.bedheight_middle.csv.header.river.elevation"; |
3bdb9f99b4a0
Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7994
diff
changeset
|
80 |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
81 public static final String CSV_META_SOUNDING_WIDTH = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
82 "export.bedheight_middle.csv.header.sounding.width"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
83 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
84 public static final String CSV_META_RANGE = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
85 "export.bedheight_middle.csv.header.range"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
86 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
87 public static final String CSV_META_LOC_SYSTEM = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
88 "export.bedheight_middle.csv.header.location.system"; |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
89 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
90 public static final String CSV_META_EVAL_BY = |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
91 "export.bedheight_middle.csv.header.evalby"; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
92 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
93 protected List<MiddleBedHeightData> data; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
94 |
7077
0a337f0005c2
Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6351
diff
changeset
|
95 public MiddleBedHeightExporter() { |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
96 data = new ArrayList<MiddleBedHeightData>(); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
97 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
98 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
99 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
100 protected void addData(Object d) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
101 if (d instanceof CalculationResult) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
102 d = ((CalculationResult) d).getData(); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
103 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
104 if (d instanceof MiddleBedHeightData[]) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
105 log.debug("Add new data of type MiddleBedHeightData"); |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
106 for (MiddleBedHeightData mD :(MiddleBedHeightData[]) d) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
107 data.add(mD); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
108 } |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
109 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
110 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
111 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
112 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
113 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
114 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
115 protected void writeCSVData(CSVWriter writer) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
116 log.info("MiddleBedHeightExporter.writeCSVData"); |
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
117 log.debug("CSV gets " + data.size() + " MiddleBedHeightData objects."); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
118 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
119 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
120 Collections.sort(data); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
121 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
122 for (MiddleBedHeightData d: data) { |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
123 data2CSV(writer, d); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
124 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
125 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
126 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
127 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
128 protected void writeCSVHeader(CSVWriter writer) { |
7600
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
129 River river = RiverUtils.getRiver((D4EArtifact) master); |
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
130 String riverUnit = river.getWstUnit().getName(); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
131 writer.writeNext(new String[] { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
132 msg(CSV_KM, CSV_KM), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
133 msg(CSV_SOUNDING, CSV_SOUNDING), |
7600
410fbd6a6d01
issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7088
diff
changeset
|
134 msg(CSV_HEIGHT, CSV_HEIGHT, new Object[] {riverUnit}), |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
135 msg(CSV_UNCERTAINTY, CSV_UNCERTAINTY), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
136 msg(CSV_DATA_GAP, CSV_DATA_GAP), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
137 msg(CSV_SOUNDING_WIDTH, CSV_SOUNDING_WIDTH), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
138 msg(CSV_WIDTH, CSV_WIDTH), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
139 msg(CSV_LOCATIONS, CSV_LOCATIONS) |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
140 }); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
141 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
142 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
143 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
144 protected void data2CSV(CSVWriter writer, MiddleBedHeightData data) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
145 log.debug("Add next MiddleBedHeightData to CSV"); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
146 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
147 D4EArtifact flys = (D4EArtifact) master; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
148 |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
149 writeMetaData(writer, data); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
150 |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
151 writeCSVHeader(writer); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
152 |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
153 NumberFormat kmF = Formatter.getMiddleBedHeightKM(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
154 NumberFormat heightF = Formatter.getMiddleBedHeightHeight(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
155 NumberFormat uncertF = Formatter.getMiddleBedHeightUncert(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
156 NumberFormat gapF = Formatter.getMiddleBedHeightDataGap(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
157 NumberFormat soundF = Formatter.getMiddleBedHeightSounding(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
158 NumberFormat widthF = Formatter.getMiddleBedHeightWidth(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
159 |
4929
1366277655b9
Bedheights: Write sounding name and set max fraction digits in calculation output.
Raimund Renkert <rrenkert@intevation.de>
parents:
3042
diff
changeset
|
160 heightF.setMaximumFractionDigits(1); |
1366277655b9
Bedheights: Write sounding name and set max fraction digits in calculation output.
Raimund Renkert <rrenkert@intevation.de>
parents:
3042
diff
changeset
|
161 soundF.setMaximumFractionDigits(1); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
162 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
163 SortedMap <Double, Integer> kmIndexMap = new TreeMap<Double, Integer>(); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
164 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
165 for (int i = 0, n = data.size(); i < n; i++) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
166 kmIndexMap.put(data.getKM(i), i); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
167 } |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
168 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
169 for (int i: kmIndexMap.values()) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
170 int start = data.getStartYear(); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
171 int end = data.getEndYear(); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
172 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
173 if (start == end) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
174 String uncert = !Double.isNaN(data.getUncertainty(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
175 uncertF.format(data.getUncertainty(i)) : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
176 String gap = !Double.isNaN(data.getDataGap(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
177 gapF.format(data.getDataGap(i)) + "%" : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
178 String sound = !Double.isNaN(data.getSoundingWidth(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
179 soundF.format(data.getSoundingWidth(i)) : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
180 writer.writeNext(new String[] { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
181 kmF.format(data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
182 data.getDescription(), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
183 heightF.format(data.getMiddleHeight(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
184 uncert, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
185 gap, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
186 sound, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
187 widthF.format(data.getWidth(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
188 RiverUtils.getLocationDescription(flys, data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
189 }); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
190 } |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
191 else { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
192 writer.writeNext(new String[] { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
193 kmF.format(data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
194 data.getDescription(), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
195 heightF.format(data.getMiddleHeight(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
196 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
197 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
198 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
199 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
200 RiverUtils.getLocationDescription(flys, data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
201 }); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
202 } |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
203 |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
204 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
205 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
206 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
207 |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
208 private void writeMetaData(CSVWriter writer, MiddleBedHeightData data) { |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
209 writer.writeNext(new String[]{"#"}); |
8011
60cd665b1bd6
Write an empty string if year is 0 in middle bedheight exporter.
Raimund Renkert <rrenkert@intevation.de>
parents:
7999
diff
changeset
|
210 String year = ""; |
60cd665b1bd6
Write an empty string if year is 0 in middle bedheight exporter.
Raimund Renkert <rrenkert@intevation.de>
parents:
7999
diff
changeset
|
211 if (data.getStartYear() != 0) { |
60cd665b1bd6
Write an empty string if year is 0 in middle bedheight exporter.
Raimund Renkert <rrenkert@intevation.de>
parents:
7999
diff
changeset
|
212 year = String.valueOf(data.getStartYear()); |
60cd665b1bd6
Write an empty string if year is 0 in middle bedheight exporter.
Raimund Renkert <rrenkert@intevation.de>
parents:
7999
diff
changeset
|
213 } |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
214 writer.writeNext(new String[]{"# " + msg(CSV_META_YEAR) + |
8011
60cd665b1bd6
Write an empty string if year is 0 in middle bedheight exporter.
Raimund Renkert <rrenkert@intevation.de>
parents:
7999
diff
changeset
|
215 ": " + year}); |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
216 writer.writeNext(new String[]{"# " + msg(CSV_META_TYPE) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
217 ": " + data.getType()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
218 writer.writeNext(new String[]{"# " + msg(CSV_META_LOC_SYSTEM) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
219 ": " + data.getLocationSystem()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
220 writer.writeNext(new String[]{"# " + msg(CSV_META_CUR_ELEV_MODEL) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
221 ": " + data.getCurElevationModel()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
222 writer.writeNext(new String[]{"# " + msg(CSV_META_OLD_ELEV_MODEL) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
223 ": " + data.getOldElevationModel()}); |
7999
3bdb9f99b4a0
Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7994
diff
changeset
|
224 writer.writeNext(new String[]{"# " + msg(CSV_META_RIVER_ELEV_MODEL) + |
3bdb9f99b4a0
Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7994
diff
changeset
|
225 ": " + data.getRiverElevationModel()}); |
7994
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
226 writer.writeNext(new String[]{"# " + msg(CSV_META_SOUNDING_WIDTH) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
227 ": " + data.getSoundingWidth()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
228 writer.writeNext(new String[]{"# " + msg(CSV_META_RANGE) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
229 ": " + data.getStations().min() + " - " + data.getStations().max()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
230 writer.writeNext(new String[]{"# " + msg(CSV_META_EVAL_BY) + |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
231 ": " + data.getEvaluatedBy()}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
232 writer.writeNext(new String[]{"#"}); |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
233 } |
3c1a16755e61
Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents:
7983
diff
changeset
|
234 |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
235 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
236 protected void writePDF(OutputStream out) { |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8011
diff
changeset
|
237 log.error("TODO: Implement FlowVelocityExporter.writePDF"); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
238 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
239 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
240 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 : |