Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/process/DischargeProcessor.java @ 7075:253d80af5b7f generator-refactoring
More Processor refactoring
- Unify aandf aaf and bundle variable names to bundle
- Factor out diagram inversion code
- Add function with new signature to BedDiffYear and QOut processors
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Fri, 20 Sep 2013 16:25:43 +0200 |
parents | f9d5020af0af |
children | 67e87c2d3748 |
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, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
61 ArtifactAndFacet bundle, |
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(); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
67 Object data = bundle.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( |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
70 generator, (WQKms) data, bundle, 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( |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
75 generator, (RiverAnnotation) data, bundle, 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( |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
80 generator, (double[][]) data, bundle, theme, visible); |
6922
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 " |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
86 + bundle.getFacetName()); |
6922
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, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
112 ArtifactAndFacet bundle, |
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"); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
118 String title = bundle.getFacetDescription(); |
6880
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, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
150 ArtifactAndFacet bundle, |
6922
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, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
166 bundle, theme, visible); |
6922
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, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
176 ArtifactAndFacet bundle, |
6922
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. |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
187 String title = bundle.getFacetDescription(); |
6922
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), |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7059
diff
changeset
|
198 bundle, theme, visible); |
6922
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 : |