Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/process/FixDerivedProcessor.java @ 9801:1d7a72a50183 3.2.x tip
Assume Compose V2, consistently
author | Tom Gottfried <tom@intevation.de> |
---|---|
date | Thu, 23 Nov 2023 10:14:13 +0100 |
parents | 0a5239a1e46e |
children |
rev | line source |
---|---|
8858 | 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 | |
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 |
9726 | 13 import org.apache.logging.log4j.Logger; |
14 import org.apache.logging.log4j.LogManager; | |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
15 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet; |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
16 import org.dive4elements.artifacts.CallContext; |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
17 import org.dive4elements.artifacts.CallMeta; |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
18 import org.dive4elements.river.artifacts.D4EArtifact; |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
19 import org.dive4elements.river.artifacts.access.RiverAccess; |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
20 import org.dive4elements.river.artifacts.model.FacetTypes; |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
21 import org.dive4elements.river.artifacts.model.fixings.FixDerivateFacet; |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
22 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
|
23 import org.dive4elements.river.artifacts.resources.Resources; |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
24 import org.dive4elements.river.exports.DiagramGenerator; |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
25 import org.dive4elements.river.jfree.JFreeUtil; |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
26 import org.dive4elements.river.jfree.StyledXYSeries; |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
27 import org.dive4elements.river.themes.ThemeDocument; |
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 |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
30 public class FixDerivedProcessor |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
31 extends DefaultProcessor |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
32 implements FacetTypes |
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 |
9726 | 35 private static Logger log = LogManager.getLogger(FixDerivedProcessor.class); |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
36 |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
37 private String yAxisLabel = ""; |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
38 |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
39 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
|
40 |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
41 |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
42 public FixDerivedProcessor() { |
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 |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
45 @Override |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
46 public void doOut( |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
47 DiagramGenerator generator, |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
48 ArtifactAndFacet bundle, |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
49 ThemeDocument theme, |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
50 boolean visible |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
51 ) { |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
52 CallContext context = generator.getCallContext(); |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
53 Map<String, String> metaData = bundle.getFacet().getMetaData( |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
54 bundle.getArtifact(), context); |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
55 FixDerivateFacet facet = (FixDerivateFacet)bundle.getFacet(); |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
56 FixFunction func = (FixFunction)facet.getData( |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
57 bundle.getArtifact(), generator.getCallContext()); |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
58 |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
59 yAxisLabel = metaData.get("Y"); |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
60 |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
61 |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
62 if (func == null) { |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
63 log.warn("doOut: Facet does not contain FixFunction"); |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
64 return; |
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 |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
67 double maxQ = func.getMaxQ(); |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
68 |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
69 if (maxQ > 0) { |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
70 StyledXYSeries series = JFreeUtil.sampleFunction2D( |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
71 func.getFunction(), |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
72 theme, |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
73 bundle.getFacetDescription(), |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
74 500, // number of samples |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
75 0.0 , // start |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
76 maxQ); // end |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
77 generator.addAxisSeries(series, axisName, visible); |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
78 series.putMetaData(metaData, bundle.getArtifact(), context); |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
79 } |
8374
2cabecf27ccc
Added km sub title to fix derivate curve, too.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8354
diff
changeset
|
80 |
8207
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 |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
83 @Override |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
84 public boolean canHandle(String facettype) { |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
85 return FIX_DERIVATE_CURVE.equals(facettype); |
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
86 } |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
87 |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
88 @Override |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
89 public String getAxisLabel(DiagramGenerator generator) { |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
90 CallMeta meta = generator.getCallContext().getMeta(); |
8856 | 91 RiverAccess access = |
92 new RiverAccess((D4EArtifact)generator.getMaster()); | |
8354
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
93 String unit = access.getRiver().getWstUnit().getName(); |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
94 |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
95 if (yAxisLabel != null && !yAxisLabel.isEmpty()) { |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
96 return Resources.getMsg( |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
97 meta, |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
98 yAxisLabel, |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
99 new Object[] { unit }); |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
100 } |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
101 return Resources.getMsg( |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
102 meta, |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
103 I18N_AXIS_LABEL, |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
104 new Object[] { unit }); |
9f9857f6c464
Added y axis label to discharge processors.
Raimund Renkert <rrenkert@intevation.de>
parents:
8207
diff
changeset
|
105 } |
8207
de280599dd2f
Added new processor for fix derived curve.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
106 } |