annotate artifacts/src/main/java/org/dive4elements/river/exports/process/FixDerivedProcessor.java @ 8858:a805211690f7 3.2.x

Fix license headers.
author Tom Gottfried <tom@intevation.de>
date Thu, 18 Jan 2018 20:52:41 +0100
parents 5e38e2924c07
children 1cc7653ca84f 0a5239a1e46e
rev   line source
8858
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
2 * Software engineering by Intevation GmbH
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
3 *
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
6 * documentation coming with Dive4Elements River for details.
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
7 */
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
8
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
10
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
11 import java.util.Map;
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
12
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
15 import org.dive4elements.artifacts.CallContext;
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
16 import org.dive4elements.artifacts.CallMeta;
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
17 import org.dive4elements.river.artifacts.D4EArtifact;
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
18 import org.dive4elements.river.artifacts.access.RiverAccess;
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.artifacts.model.fixings.FixDerivateFacet;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.artifacts.model.fixings.FixFunction;
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
22 import org.dive4elements.river.artifacts.resources.Resources;
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.exports.DiagramGenerator;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.jfree.JFreeUtil;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
25 import org.dive4elements.river.jfree.StyledXYSeries;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
26 import org.dive4elements.river.themes.ThemeDocument;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
27
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
29 public class FixDerivedProcessor
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
30 extends DefaultProcessor
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
31 implements FacetTypes
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
32 {
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
33
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34 private static Logger log = Logger.getLogger(FixDerivedProcessor.class);
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
36 private String yAxisLabel = "";
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
37
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
38 private String I18N_AXIS_LABEL = "chart.discharge.curve.yaxis.label";
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
39
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
40
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
41 public FixDerivedProcessor() {
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
42 }
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
43
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
44 @Override
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
45 public void doOut(
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
46 DiagramGenerator generator,
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
47 ArtifactAndFacet bundle,
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
48 ThemeDocument theme,
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
49 boolean visible
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
50 ) {
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
51 CallContext context = generator.getCallContext();
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
52 Map<String, String> metaData = bundle.getFacet().getMetaData(
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
53 bundle.getArtifact(), context);
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
54 FixDerivateFacet facet = (FixDerivateFacet)bundle.getFacet();
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
55 FixFunction func = (FixFunction)facet.getData(
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
56 bundle.getArtifact(), generator.getCallContext());
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
58 yAxisLabel = metaData.get("Y");
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
59
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
60
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
61 if (func == null) {
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
62 log.warn("doOut: Facet does not contain FixFunction");
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
63 return;
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
64 }
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
65
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
66 double maxQ = func.getMaxQ();
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
67
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
68 if (maxQ > 0) {
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
69 StyledXYSeries series = JFreeUtil.sampleFunction2D(
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
70 func.getFunction(),
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
71 theme,
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
72 bundle.getFacetDescription(),
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
73 500, // number of samples
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
74 0.0 , // start
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
75 maxQ); // end
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
76 generator.addAxisSeries(series, axisName, visible);
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
77 series.putMetaData(metaData, bundle.getArtifact(), context);
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
78 }
8374
2cabecf27ccc Added km sub title to fix derivate curve, too.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 8354
diff changeset
79
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
80 }
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
81
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
82 @Override
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
83 public boolean canHandle(String facettype) {
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
84 return FIX_DERIVATE_CURVE.equals(facettype);
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
85 }
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
86
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
87 @Override
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
88 public String getAxisLabel(DiagramGenerator generator) {
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
89 CallMeta meta = generator.getCallContext().getMeta();
8856
5e38e2924c07 Fix code style.
Tom Gottfried <tom@intevation.de>
parents: 8387
diff changeset
90 RiverAccess access =
5e38e2924c07 Fix code style.
Tom Gottfried <tom@intevation.de>
parents: 8387
diff changeset
91 new RiverAccess((D4EArtifact)generator.getMaster());
8354
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
92 String unit = access.getRiver().getWstUnit().getName();
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
93
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
94 if (yAxisLabel != null && !yAxisLabel.isEmpty()) {
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
95 return Resources.getMsg(
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
96 meta,
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
97 yAxisLabel,
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
98 new Object[] { unit });
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
99 }
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
100 return Resources.getMsg(
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
101 meta,
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
102 I18N_AXIS_LABEL,
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
103 new Object[] { unit });
9f9857f6c464 Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents: 8207
diff changeset
104 }
8207
de280599dd2f Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
105 }

http://dive4elements.wald.intevation.org