annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedQualityDiameterProcessor.java @ 7148:cde7db30847f

Add BedQuality Processors
author Andre Heinecke <aheinecke@intevation.de>
date Wed, 25 Sep 2013 15:57:50 +0200
parents
children 1508ee33f85f
rev   line source
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2013 by Bundesanstalt für Gewässerkunde
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
3 *
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
7 */
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
8
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
10
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
11 import java.util.List;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
12
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
14 import org.jfree.data.xy.XYSeries;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
15
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
16 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
17 import org.dive4elements.artifacts.CallContext;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
18 import org.dive4elements.river.artifacts.model.minfo.BedHeightSingle;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.exports.DiagramGenerator;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.exports.StyledSeriesBuilder;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.jfree.StyledXYSeries;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.model.BedHeightSingleValue;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.themes.ThemeDocument;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
25
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
26 import org.dive4elements.river.artifacts.model.minfo.BedDiameterData;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
27 import org.dive4elements.river.artifacts.model.minfo.BedDiameterResult;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
28 import org.dive4elements.river.artifacts.model.minfo.BedloadDiameterResult;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
29
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
30 public class BedQualityDiameterProcessor extends DefaultProcessor {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
31
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
32 private final static Logger logger =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
33 Logger.getLogger(BedQualityDiameterProcessor.class);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
34
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
35 public static final String I18N_AXIS_LABEL_DEFAULT =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
36 "Durchmesser [mm]";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
37 public static final String I18N_AXIS_LABEL =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
38 "chart.bedquality.yaxis.label.diameter";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
39
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
40 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
41 public void doOut(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
42 DiagramGenerator generator,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
43 ArtifactAndFacet bundle,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
44 ThemeDocument theme,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
45 boolean visible) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
46 CallContext context = generator.getCallContext();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
47 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
48 theme);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
49 Object data = bundle.getData(context);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
50 String facetName = bundle.getFacetName();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
51 double [][] points;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
52
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
53 if (facetName.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_TOPLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
54 points = ((BedDiameterResult) data).getDiameterCapData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
55 } else if (facetName.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_SUBLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
56 points = ((BedDiameterResult) data).getDiameterSubData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
57 } else if (facetName.equals(FacetTypes.BED_QUALITY_BEDLOAD_DIAMETER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
58 points = ((BedloadDiameterResult) data).getDiameterData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
59 } else if (facetName.equals(FacetTypes.BED_DIAMETER_DATA_TOP) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
60 facetName.equals(FacetTypes.BED_DIAMETER_DATA_SUB) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
61 facetName.equals(FacetTypes.BEDLOAD_DIAMETER_DATA)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
62 points = ((BedDiameterData) data).getDiameterData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
63 } else {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
64 logger.error("Unknown facet name: " + facetName);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
65 return;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
66 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
67 StyledSeriesBuilder.addPoints(series, points, true);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
68
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
69 generator.addAxisSeries(series, axisName, visible);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
70 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
71
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
72 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
73 public boolean canHandle(String facettype) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
74 return facettype.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_TOPLAYER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
75 facettype.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_SUBLAYER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
76 facettype.equals(FacetTypes.BED_QUALITY_BEDLOAD_DIAMETER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
77 facettype.equals(FacetTypes.BED_DIAMETER_DATA_TOP) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
78 facettype.equals(FacetTypes.BED_DIAMETER_DATA_SUB) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
79 facettype.equals(FacetTypes.BEDLOAD_DIAMETER_DATA);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
80 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
81
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
82 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
83 public String getAxisLabel(DiagramGenerator generator) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
84 return generator.msg(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
85 I18N_AXIS_LABEL,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
86 I18N_AXIS_LABEL_DEFAULT);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
87 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
88 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
89

http://dive4elements.wald.intevation.org