Mercurial > dive4elements > river
comparison artifacts/src/main/java/org/dive4elements/river/exports/process/FixDeltaWAProcessor.java @ 7523:ce90d2f4ee46
issue1664: Add new Processors to old axis and map them in longitudinal-diagram-defaults.
Sorry for simultaneous formatting changes.
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Wed, 06 Nov 2013 12:03:38 +0100 |
parents | |
children | e4606eae8ea5 |
comparison
equal
deleted
inserted
replaced
7522:f062802c9a4a | 7523:ce90d2f4ee46 |
---|---|
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde | |
2 * Software engineering by Intevation GmbH | |
3 * | |
4 * This file is Free Software under the GNU AGPL (>=v3) | |
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
6 * documentation coming with Dive4Elements River for details. | |
7 */ | |
8 | |
9 package org.dive4elements.river.exports.process; | |
10 | |
11 import org.apache.log4j.Logger; | |
12 import org.jfree.data.xy.XYSeries; | |
13 | |
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet; | |
15 import org.dive4elements.artifacts.CallContext; | |
16 import org.dive4elements.river.artifacts.model.FacetTypes; | |
17 import org.dive4elements.river.artifacts.model.WKms; | |
18 import org.dive4elements.river.exports.StyledSeriesBuilder; | |
19 import org.dive4elements.river.exports.DiagramGenerator; | |
20 import org.dive4elements.river.jfree.StyledAreaSeriesCollection; | |
21 import org.dive4elements.river.jfree.StyledXYSeries; | |
22 import org.dive4elements.river.themes.ThemeDocument; | |
23 | |
24 | |
25 public class FixDeltaWAProcessor | |
26 extends DefaultProcessor implements FacetTypes { | |
27 | |
28 private final static Logger logger = | |
29 Logger.getLogger(FixDeltaWAProcessor.class); | |
30 | |
31 public static final String I18N_AXIS_LABEL = | |
32 "chart.beddifference.height.yaxis.label"; | |
33 public static final String I18N_AXIS_LABEL_DEFAULT = | |
34 "delta S [cm / Jahr]"; | |
35 | |
36 @Override | |
37 public void doOut( | |
38 DiagramGenerator generator, | |
39 ArtifactAndFacet bundle, | |
40 ThemeDocument theme, | |
41 boolean visible) { | |
42 CallContext context = generator.getCallContext(); | |
43 Object data = bundle.getData(context); | |
44 | |
45 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(), theme); | |
46 | |
47 // Handle WKms data. | |
48 WKms wkms = (WKms) data; | |
49 | |
50 StyledSeriesBuilder.addPoints(series, wkms); | |
51 generator.addAxisSeries(series, axisName, visible); | |
52 | |
53 // If a "band around the curve shall be drawn, add according area. | |
54 double bandWidth = theme.parseBandWidth(); | |
55 if (bandWidth > 0 ) { | |
56 XYSeries seriesDown = new StyledXYSeries( | |
57 "band " + bundle.getFacetDescription(), false, theme); | |
58 XYSeries seriesUp = new StyledXYSeries( | |
59 bundle.getFacetDescription()+"+/-"+bandWidth, false, theme); | |
60 StyledSeriesBuilder.addUpperBand(seriesUp, wkms, bandWidth); | |
61 StyledSeriesBuilder.addLowerBand(seriesDown, wkms, bandWidth); | |
62 | |
63 StyledAreaSeriesCollection area = new StyledAreaSeriesCollection(theme); | |
64 area.addSeries(seriesUp); | |
65 area.addSeries(seriesDown); | |
66 area.setMode(StyledAreaSeriesCollection.FILL_MODE.BETWEEN); | |
67 generator.addAreaSeries(area, axisName, visible); | |
68 } | |
69 } | |
70 | |
71 @Override | |
72 public boolean canHandle(String facetType) { | |
73 return STATIC_DELTA_W_CMA.equals(facetType); | |
74 } | |
75 | |
76 @Override | |
77 public String getAxisLabel(DiagramGenerator generator) { | |
78 return generator.msg( | |
79 I18N_AXIS_LABEL, | |
80 I18N_AXIS_LABEL_DEFAULT); | |
81 } | |
82 } | |
83 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 : |