Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/MiddleBedHeightExporter.java @ 7693:c130196389df
(issue1596) Sort Export of Middle bedHeight
This simplyfies internal Data storage by removing
the ArrayList wrapper. Usually this is a list of size 1.
The data list of which each member is a distinct sounding
is then sorted by description or first indexed KM.
Afterwards the km index is mapped in a sorted map to
export it in order of km and not in oder of index
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Mon, 16 Dec 2013 12:26:52 +0100 |
parents | 410fbd6a6d01 |
children | 62befca02480 |
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; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4929
diff
changeset
|
25 import org.dive4elements.river.artifacts.model.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 |
3042
2ff802d66b71
trivial doc.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
2714
diff
changeset
|
38 /** Private logger. */ |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
39 private static final Logger logger = |
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 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
66 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
67 protected List<MiddleBedHeightData> data; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
68 |
7077
0a337f0005c2
Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6351
diff
changeset
|
69 public MiddleBedHeightExporter() { |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
70 data = new ArrayList<MiddleBedHeightData>(); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
71 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
72 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
73 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
74 protected void addData(Object d) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
75 if (d instanceof CalculationResult) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
76 d = ((CalculationResult) d).getData(); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
77 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
78 if (d instanceof MiddleBedHeightData[]) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
79 logger.debug("Add new data of type MiddleBedHeightData"); |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
80 for (MiddleBedHeightData mD :(MiddleBedHeightData[]) d) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
81 data.add(mD); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
82 } |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
83 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
84 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
85 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
86 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
87 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
88 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
89 protected void writeCSVData(CSVWriter writer) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
90 logger.info("MiddleBedHeightExporter.writeCSVData"); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
91 logger.debug("CSV gets " + data.size() + " MiddleBedHeightData objects."); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
92 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
93 writeCSVHeader(writer); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
94 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
95 Collections.sort(data); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
96 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
97 for (MiddleBedHeightData d: data) { |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
98 data2CSV(writer, d); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
99 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
100 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
101 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
102 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
103 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
|
104 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
|
105 String riverUnit = river.getWstUnit().getName(); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
106 writer.writeNext(new String[] { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
107 msg(CSV_KM, CSV_KM), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
108 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
|
109 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
|
110 msg(CSV_UNCERTAINTY, CSV_UNCERTAINTY), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
111 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
|
112 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
|
113 msg(CSV_WIDTH, CSV_WIDTH), |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
114 msg(CSV_LOCATIONS, CSV_LOCATIONS) |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
115 }); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
116 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
117 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
118 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
119 protected void data2CSV(CSVWriter writer, MiddleBedHeightData data) { |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
120 logger.debug("Add next MiddleBedHeightData to CSV"); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
121 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
122 D4EArtifact flys = (D4EArtifact) master; |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
123 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
124 NumberFormat kmF = Formatter.getMiddleBedHeightKM(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
125 NumberFormat heightF = Formatter.getMiddleBedHeightHeight(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
126 NumberFormat uncertF = Formatter.getMiddleBedHeightUncert(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
127 NumberFormat gapF = Formatter.getMiddleBedHeightDataGap(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
128 NumberFormat soundF = Formatter.getMiddleBedHeightSounding(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
129 NumberFormat widthF = Formatter.getMiddleBedHeightWidth(context); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
130 |
4929
1366277655b9
Bedheights: Write sounding name and set max fraction digits in calculation output.
Raimund Renkert <rrenkert@intevation.de>
parents:
3042
diff
changeset
|
131 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
|
132 soundF.setMaximumFractionDigits(1); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
133 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
134 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
|
135 |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
136 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
|
137 kmIndexMap.put(data.getKM(i), i); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
138 } |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
139 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
140 for (int i: kmIndexMap.values()) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
141 int start = data.getStartYear(); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
142 int end = data.getEndYear(); |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
143 |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
144 if (start == end) { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
145 String uncert = !Double.isNaN(data.getUncertainty(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
146 uncertF.format(data.getUncertainty(i)) : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
147 String gap = !Double.isNaN(data.getDataGap(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
148 gapF.format(data.getDataGap(i)) + "%" : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
149 String sound = !Double.isNaN(data.getSoundingWidth(i)) ? |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
150 soundF.format(data.getSoundingWidth(i)) : ""; |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
151 writer.writeNext(new String[] { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
152 kmF.format(data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
153 data.getDescription(), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
154 heightF.format(data.getMiddleHeight(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
155 uncert, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
156 gap, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
157 sound, |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
158 widthF.format(data.getWidth(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
159 RiverUtils.getLocationDescription(flys, data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
160 }); |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
161 } |
7693
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
162 else { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
163 writer.writeNext(new String[] { |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
164 kmF.format(data.getKM(i)), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
165 data.getDescription(), |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
166 heightF.format(data.getMiddleHeight(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 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
170 "", |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
171 RiverUtils.getLocationDescription(flys, data.getKM(i)), |
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 } |
c130196389df
(issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents:
7600
diff
changeset
|
174 |
2714
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
175 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
176 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
177 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
178 |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
179 @Override |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
180 protected void writePDF(OutputStream out) { |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
181 logger.error("TODO: Implement FlowVelocityExporter.writePDF"); |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
182 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
183 } |
2952f6dee5cf
Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff
changeset
|
184 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 : |