annotate artifacts/src/main/java/org/dive4elements/river/exports/process/ShearStressProcessor.java @ 7165:6e42f0ff0329

Add ShearStress Processor
author Andre Heinecke <aheinecke@intevation.de>
date Thu, 26 Sep 2013 12:21:11 +0200
parents
children 46ba37c22d9f
rev   line source
7165
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2013 by Bundesanstalt für Gewässerkunde
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
3 *
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
7 */
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
8
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
10
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
11 import java.util.List;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
12 import java.util.Set;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
13
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
14 import org.apache.log4j.Logger;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
15 import org.jfree.data.xy.XYSeries;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
16 import org.dive4elements.river.artifacts.D4EArtifact;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
17
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
18 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
19 import org.dive4elements.artifacts.CallContext;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.artifacts.access.SedimentLoadAccess;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.artifacts.model.FacetTypes;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.exports.DiagramGenerator;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.exports.StyledSeriesBuilder;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.jfree.StyledXYSeries;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
25 import org.dive4elements.river.themes.ThemeDocument;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
26
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
27 import org.dive4elements.river.artifacts.model.FlowVelocityData;
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
28
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
29 public class ShearStressProcessor extends DefaultProcessor {
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
30
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
31 private final static Logger logger =
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
32 Logger.getLogger(ShearStressProcessor.class);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
33
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
34 public static final String I18N_AXIS_LABEL =
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
35 "chart.flow_velocity.section.yaxis.third.label";
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
36 public static final String I18N_AXIS_LABEL_DEFAULT =
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
37 "Schubspannung Tau [N]";
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
38
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
39 @Override
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
40 public void doOut(
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
41 DiagramGenerator generator,
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
42 ArtifactAndFacet bundle,
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
43 ThemeDocument theme,
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
44 boolean visible) {
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
45 CallContext context = generator.getCallContext();
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
46 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
47 theme);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
48 String facetName = bundle.getFacetName();
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
49 FlowVelocityData data = (FlowVelocityData) bundle.getData(context);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
50
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
51 StyledSeriesBuilder.addPoints(series, data.getTauPoints(), true);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
52
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
53 generator.addAxisSeries(series, axisName, visible);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
54 }
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
55
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
56 @Override
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
57 public boolean canHandle(String facettype) {
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
58 return facettype.equals(FacetTypes.FLOW_VELOCITY_TAU) ||
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
59 facettype.equals(FacetTypes.FLOW_VELOCITY_TAU_FILTERED);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
60 }
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
61
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
62 @Override
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
63 public String getAxisLabel(DiagramGenerator generator) {
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
64 return generator.msg(
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
65 I18N_AXIS_LABEL,
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
66 I18N_AXIS_LABEL_DEFAULT);
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
67 }
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
68 }
6e42f0ff0329 Add ShearStress Processor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
69

http://dive4elements.wald.intevation.org