annotate artifacts/src/main/java/org/dive4elements/river/exports/process/SedimentDensityProcessor.java @ 7214:8817bb81cf27

Initial commit of sediment density processor.
author Felix Wolfsteller <felix.wolfsteller@intevation.de>
date Mon, 30 Sep 2013 17:40:42 +0200
parents
children 7a7ce43ddd3f
rev   line source
7214
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2013 by Bundesanstalt für Gewässerkunde
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
3 *
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
7 */
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
8
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
10
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
11 import org.apache.log4j.Logger;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
12 import org.jfree.data.xy.XYSeries;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
13
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
15 import org.dive4elements.artifacts.CallContext;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
16
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
17 import org.dive4elements.river.artifacts.model.FacetTypes;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
18 import org.dive4elements.river.artifacts.model.minfo.SedimentDensity;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
19
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.exports.DiagramGenerator;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.exports.StyledSeriesBuilder;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.jfree.StyledXYSeries;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.themes.ThemeDocument;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
24
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
25
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
26 /** Process Sediment Density data. */
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
27 public class SedimentDensityProcessor extends DefaultProcessor {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
28
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
29 /** Private logger. */
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
30 private final static Logger logger =
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
31 Logger.getLogger(SedimentDensityProcessor.class);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
32
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
33 public static final String I18N_AXIS_LABEL_DEFAULT =
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
34 "Sedimentdichte [t/m^3]";
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
35 public static final String I18N_AXIS_LABEL =
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
36 "chart.yaxis.label.sedimentdensity";
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
37
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
38 @Override
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
39 public void doOut(
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
40 DiagramGenerator generator,
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
41 ArtifactAndFacet bundle,
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
42 ThemeDocument theme,
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
43 boolean visible) {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
44 CallContext context = generator.getCallContext();
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
45 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
46 theme);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
47 Object data = bundle.getData(context);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
48 String facetName = bundle.getFacetName();
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
49 double [][] points;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
50
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
51 if (facetName.equals(FacetTypes.SEDIMENT_DENSITY)) {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
52 points =((SedimentDensity) data).getDensities(2006);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
53 } else {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
54 logger.error("Unknown facet name: " + facetName);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
55 return;
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
56 }
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
57 StyledSeriesBuilder.addPoints(series, points, true);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
58
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
59 generator.addAxisSeries(series, axisName, visible);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
60 }
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
61
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
62 @Override
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
63 public boolean canHandle(String facettype) {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
64 return facettype.equals(FacetTypes.SEDIMENT_DENSITY);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
65 }
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
66
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
67 @Override
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
68 public String getAxisLabel(DiagramGenerator generator) {
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
69 return generator.msg(
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
70 I18N_AXIS_LABEL,
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
71 I18N_AXIS_LABEL_DEFAULT);
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
72 }
8817bb81cf27 Initial commit of sediment density processor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
73 }

http://dive4elements.wald.intevation.org