annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedHeightProcessor.java @ 7396:a94b6e057daa

BedHeightProcessor: Finally display heights, not widths.
author Felix Wolfsteller <felix.wolfsteller@intevation.de>
date Thu, 17 Oct 2013 16:15:14 +0200
parents 5126cadaed58
children fab06617afb2
rev   line source
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
3 *
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
7 */
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
8
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
10
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
11 import java.util.List;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
12
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
14 import org.jfree.data.xy.XYSeries;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
15
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
16 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
17 import org.dive4elements.artifacts.CallContext;
7391
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7390
diff changeset
18 import org.dive4elements.river.artifacts.model.minfo.BedHeightSingleData;
7394
5eafd73312ae BedHeight(Sounding)Processor: Use FacetTypes.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7391
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.exports.XYChartGenerator;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.exports.DiagramGenerator;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.jfree.StyledXYSeries;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.model.BedHeightSingleValue;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.themes.ThemeDocument;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
25
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
26 public class BedHeightProcessor extends DefaultProcessor {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
27
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
28 private final static Logger logger =
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
29 Logger.getLogger(BedHeightProcessor.class);
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
30
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
31 public static final String I18N_AXIS_LABEL_DEFAULT
7395
5126cadaed58 BedHeightProcessor: Set axis label.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7394
diff changeset
32 = "Sohlhoehe [m]";
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
33 public static final String I18N_AXIS_LABEL =
7395
5126cadaed58 BedHeightProcessor: Set axis label.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7394
diff changeset
34 "chart.bedheight.height.yaxis.label";
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
35
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
36 @Override
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
37 public void doOut(
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
38 DiagramGenerator generator,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
39 ArtifactAndFacet bundle,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
40 ThemeDocument theme,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
41 boolean visible) {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
42 XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
43 generator.addAxisSeries(series, axisName, visible);
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
44 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
45
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
46 @Override
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
47 public void doOut(
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
48 XYChartGenerator generator,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
49 ArtifactAndFacet bundle,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
50 ThemeDocument theme,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
51 boolean visible,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
52 int index
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
53 ) {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
54 XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
55 generator.addAxisSeries(series, index, visible);
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
56 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
57
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
58 /** Prepare an series, independent of axis. */
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
59 private XYSeries prepareSeries(ArtifactAndFacet bundle,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
60 ThemeDocument theme, CallContext context) {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
61 Object data = bundle.getData(context);
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
62 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
63 theme);
7391
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7390
diff changeset
64 if (data instanceof BedHeightSingleData) {
9513d1af7d58 Renamed artifacts/**/BedHeight(Single) to BedHeight(Single)Data, to resolve
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7390
diff changeset
65 BedHeightSingleData bData = (BedHeightSingleData)data;
7396
a94b6e057daa BedHeightProcessor: Finally display heights, not widths.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7395
diff changeset
66 double[] heights = bData.getHeights();
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
67 double[] stations = bData.getStations().toNativeArray();
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
68
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
69 logger.debug("doBedheightSingleOut");
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
70
7396
a94b6e057daa BedHeightProcessor: Finally display heights, not widths.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7395
diff changeset
71 for (int i = 0; i < heights.length; i++) {
a94b6e057daa BedHeightProcessor: Finally display heights, not widths.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7395
diff changeset
72 series.add(stations[i], heights[i], false);
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
73 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
74 } else if (data instanceof List<?>) {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
75 List<BedHeightSingleValue> bData = (List<BedHeightSingleValue>)data;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
76
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
77 logger.debug("doBedheightSingleValueOut");
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
78
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
79 for(BedHeightSingleValue bvalue: bData) {
7396
a94b6e057daa BedHeightProcessor: Finally display heights, not widths.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7395
diff changeset
80 series.add(bvalue.getStation(), bvalue.getHeight());
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
81 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
82 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
83 else {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
84 logger.error("Unknown data type " + data.getClass());
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
85 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
86 return series;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
87 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
88
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
89
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
90 @Override
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
91 public boolean canHandle(String facettype) {
7394
5eafd73312ae BedHeight(Sounding)Processor: Use FacetTypes.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7391
diff changeset
92 return FacetTypes.BEDHEIGHT.equals(facettype);
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
93 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
94
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
95 @Override
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
96 public String getAxisLabel(DiagramGenerator generator) {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
97 return generator.msg(
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
98 I18N_AXIS_LABEL,
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
99 I18N_AXIS_LABEL_DEFAULT);
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
100 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
101 }

http://dive4elements.wald.intevation.org