annotate artifacts/src/main/java/org/dive4elements/river/exports/process/DischargeProcessor.java @ 7059:f9d5020af0af generator-refactoring

Remove AxisProcessor "glue" class and extend Processor interface
author Andre Heinecke <aheinecke@intevation.de>
date Fri, 20 Sep 2013 10:30:03 +0200
parents 6fb355b87f50
children 253d80af5b7f
rev   line source
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
3 *
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
7 */
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
8
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
10
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
11 import java.util.ArrayList;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
12 import java.util.List;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
13
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
14 import org.apache.log4j.Logger;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
15 import org.jfree.data.xy.XYSeries;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
16
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
17 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
18 import org.dive4elements.artifacts.CallContext;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.artifacts.model.WQKms;
6898
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
21 import org.dive4elements.river.exports.DischargeCurveGenerator;
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.exports.XYChartGenerator;
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
23 import org.dive4elements.river.jfree.CollisionFreeXYTextAnnotation;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
24 import org.dive4elements.river.jfree.RiverAnnotation;
6922
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
25 import org.dive4elements.river.jfree.StickyAxisAnnotation;
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
26 import org.dive4elements.river.jfree.StyledXYSeries;
6905
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6898
diff changeset
27 import org.dive4elements.river.themes.ThemeDocument;
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
28
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
29 import org.jfree.chart.annotations.XYTextAnnotation;
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
30
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
31
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
32 /** Helper for data handling in discharge diagrams. */
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
33 public class DischargeProcessor
7059
f9d5020af0af Remove AxisProcessor "glue" class and extend Processor interface
Andre Heinecke <aheinecke@intevation.de>
parents: 6922
diff changeset
34 extends DefaultProcessor implements FacetTypes {
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
35
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
36 private final static Logger logger =
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
37 Logger.getLogger(DischargeProcessor.class);
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
38
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
39 /** Station for which the diagram is shown. */
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
40 private double km;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
41
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
42 /** Tolerance for comparison of kilometers. */
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
43 public static final double KM_EPSILON = 0.001d;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
44
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
45
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
46 /** This processor needs to be constructed with a given km. */
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
47 private DischargeProcessor() {
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
48 km = Double.NaN;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
49 }
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
50
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
51
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
52 public DischargeProcessor(double km) {
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
53 this.km = km;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
54 }
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
55
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
56
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
57 /** Process data, add it to plot. */
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
58 @Override
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
59 public void doOut(
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
60 XYChartGenerator generator,
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
61 ArtifactAndFacet aandf,
6905
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6898
diff changeset
62 ThemeDocument theme,
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
63 boolean visible,
6914
695a5f6599b4 Minor refactoring, renamed variable, extracted method.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
64 int axisIndex
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
65 ) {
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
66 CallContext context = generator.getCallContext();
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
67 Object data = aandf.getData(context);
6898
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
68 if (false && data instanceof WQKms) {
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
69 doWQKmsPointOut(
6914
695a5f6599b4 Minor refactoring, renamed variable, extracted method.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
70 generator, (WQKms) data, aandf, theme, visible, axisIndex);
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
71 return;
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
72 }
6898
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
73 else if (data instanceof RiverAnnotation) {
6914
695a5f6599b4 Minor refactoring, renamed variable, extracted method.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
74 doRiverAnnotationOut(
695a5f6599b4 Minor refactoring, renamed variable, extracted method.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
75 generator, (RiverAnnotation) data, aandf, theme, visible);
6898
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
76 return;
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
77 }
6922
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
78 else if (data instanceof double[][]) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
79 doMarksOut(
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
80 generator, (double[][]) data, aandf, theme, visible);
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
81 return;
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
82 }
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
83 else {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
84 logger.error("Can't process "
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
85 + data.getClass().getName() + " objects of facet "
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
86 + aandf.getFacetName());
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
87 }
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
88 }
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
89
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
90
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
91 /** True if this processor knows how to deal with facetType. */
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
92 @Override
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
93 public boolean canHandle(String facetType) {
6898
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
94 return /*STATIC_WQKMS_W.equals(facetType)
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
95 ||*/ COMPUTED_DISCHARGE_MAINVALUES_Q.equals(facetType)
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
96 || MAINVALUES_Q.equals(facetType)
ebe7dfffacc4 DischargeProcessor: Handle main-values. Temporarily disable w/q data handling.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6897
diff changeset
97 || COMPUTED_DISCHARGE_MAINVALUES_W.equals(facetType)
6922
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
98 || MAINVALUES_W.equals(facetType)
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
99 || STATIC_W_INTERPOL.equals(facetType);
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
100 }
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
101
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
102
6897
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
103 /** The station of the current calculation/view. */
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
104 protected double getKm() {
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
105 return km;
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
106 }
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
107
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
108
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
109 /** Handle WQKms data by finding w/q values at given km. */
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
110 protected void doWQKmsPointOut(XYChartGenerator generator,
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
111 WQKms wqkms,
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
112 ArtifactAndFacet aandf,
6905
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6898
diff changeset
113 ThemeDocument theme,
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
114 boolean visible,
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
115 int axidx
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
116 ) {
6914
695a5f6599b4 Minor refactoring, renamed variable, extracted method.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6905
diff changeset
117 logger.debug("doWQKmsPointOut");
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
118 String title = aandf.getFacetDescription();
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
119 XYSeries series = new StyledXYSeries(
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
120 title,
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
121 theme);
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
122
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
123 double[] kms = wqkms.getKms();
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
124
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
125 for (int i = 0 ; i< kms.length; i++) {
6897
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
126 if (Math.abs(kms[i] - getKm()) <= KM_EPSILON) {
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
127 series.add(wqkms.getQ(i), wqkms.getW(i));
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
128 generator.addAxisSeries(series, axidx, visible);
6905
1b35b2ddfc28 Artifacts: Introduce ThemeDocument & make stuff compileable again. THIS BREAKS THE SYSTEM! TODO: Move ThemeUtils into ThemeDocument.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6898
diff changeset
129 if(visible && theme.parseShowPointLabel()) {
6880
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
130 List<XYTextAnnotation> textAnnos = new ArrayList<XYTextAnnotation>();
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
131 XYTextAnnotation anno = new CollisionFreeXYTextAnnotation(
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
132 title,
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
133 wqkms.getQ(i),
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
134 // TODO add a percentage to the extend of W axis
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
135 wqkms.getW(i));
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
136 textAnnos.add(anno);
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
137 RiverAnnotation flysAnno = new RiverAnnotation(null, null, null, theme);
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
138 flysAnno.setTextAnnotations(textAnnos);
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
139 generator.addAnnotations(flysAnno);
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
140 }
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
141 return;
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
142 }
8a4e344b309a issue1378: Preparing DischargeProcessor to be able to draw W/Q points,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6878
diff changeset
143 }
6897
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
144
34c04d877149 DischargeProcessor: Minor refactoring (use getter), warn when no Ẁ/Q data found.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6892
diff changeset
145 logger.warn("No WQ found for km " + getKm());
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
146 }
6922
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
147
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
148 protected void doRiverAnnotationOut(XYChartGenerator generator,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
149 RiverAnnotation annotations,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
150 ArtifactAndFacet aandf,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
151 ThemeDocument theme,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
152 boolean visible
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
153 ) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
154 if (!(generator instanceof DischargeCurveGenerator)) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
155 logger.error("DischargeProcessor can only be used in " +
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
156 " in DischargeCurveGenerator-classes.");
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
157 return;
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
158 }
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
159 logger.debug("doRiverAnnotationOut");
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
160 DischargeCurveGenerator dGenerator =
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
161 (DischargeCurveGenerator) generator;
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
162
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
163 dGenerator.translateRiverAnnotation(annotations);
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
164 dGenerator.doAnnotations(
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
165 annotations,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
166 aandf, theme, visible);
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
167 }
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
168
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
169
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
170 /**
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
171 * Put Sticky Axis Markers to Y-axis for each value.
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
172 * @param data [[-,y1],[-,y2],...] ('x'-coordinates ignored)
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
173 */
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
174 protected void doMarksOut(XYChartGenerator generator,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
175 double[][] data,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
176 ArtifactAndFacet aandf,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
177 ThemeDocument theme,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
178 boolean visible
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
179 ) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
180 logger.debug("doMarksOut");
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
181
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
182 if (!visible) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
183 return;
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
184 }
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
185
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
186 // TODO subtract gauge null point if at gauge.
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
187 String title = aandf.getFacetDescription();
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
188 List<StickyAxisAnnotation> yMarks = new ArrayList<StickyAxisAnnotation>();
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
189
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
190 for (double yPos: data[1]) {
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
191 yMarks.add(new StickyAxisAnnotation(
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
192 title,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
193 (float) yPos,
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
194 StickyAxisAnnotation.SimpleAxis.Y_AXIS));
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
195 }
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
196
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
197 generator.doAnnotations(new RiverAnnotation(title, yMarks),
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
198 aandf, theme, visible);
6fb355b87f50 DischargeProcessor: Handle interpolated w values
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6914
diff changeset
199 }
6878
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
200 }
9b35bf3227e9 Initial DischargeProcessor-commit (skeleton).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
201 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org