annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedQualityDiameterProcessor.java @ 7167:2fd238b681a9

Add debug output triggered by debugging the last commit
author Andre Heinecke <aheinecke@intevation.de>
date Thu, 26 Sep 2013 12:22:01 +0200
parents 1508ee33f85f
children e844be34a606
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 org.apache.log4j.Logger;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
12 import org.jfree.data.xy.XYSeries;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
13
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
15 import org.dive4elements.artifacts.CallContext;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
16 import org.dive4elements.river.artifacts.model.FacetTypes;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
17 import org.dive4elements.river.exports.DiagramGenerator;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
18 import org.dive4elements.river.exports.StyledSeriesBuilder;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.jfree.StyledXYSeries;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.themes.ThemeDocument;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
21
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.artifacts.model.minfo.BedDiameterData;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
23 import org.dive4elements.river.artifacts.model.minfo.BedDiameterResult;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.artifacts.model.minfo.BedloadDiameterResult;
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 public class BedQualityDiameterProcessor extends DefaultProcessor {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
27
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
28 private final static Logger logger =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
29 Logger.getLogger(BedQualityDiameterProcessor.class);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
30
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
31 public static final String I18N_AXIS_LABEL_DEFAULT =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
32 "Durchmesser [mm]";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
33 public static final String I18N_AXIS_LABEL =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
34 "chart.bedquality.yaxis.label.diameter";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
35
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
36 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
37 public void doOut(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
38 DiagramGenerator generator,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
39 ArtifactAndFacet bundle,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
40 ThemeDocument theme,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
41 boolean visible) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
42 CallContext context = generator.getCallContext();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
43 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
44 theme);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
45 Object data = bundle.getData(context);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
46 String facetName = bundle.getFacetName();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
47 double [][] points;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
48
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
49 if (facetName.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_TOPLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
50 points = ((BedDiameterResult) data).getDiameterCapData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
51 } else if (facetName.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_SUBLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
52 points = ((BedDiameterResult) data).getDiameterSubData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
53 } else if (facetName.equals(FacetTypes.BED_QUALITY_BEDLOAD_DIAMETER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
54 points = ((BedloadDiameterResult) data).getDiameterData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
55 } else if (facetName.equals(FacetTypes.BED_DIAMETER_DATA_TOP) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
56 facetName.equals(FacetTypes.BED_DIAMETER_DATA_SUB) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
57 facetName.equals(FacetTypes.BEDLOAD_DIAMETER_DATA)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
58 points = ((BedDiameterData) data).getDiameterData();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
59 } else {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
60 logger.error("Unknown facet name: " + facetName);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
61 return;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
62 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
63 StyledSeriesBuilder.addPoints(series, points, true);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
64
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
65 generator.addAxisSeries(series, axisName, visible);
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
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
68 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
69 public boolean canHandle(String facettype) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
70 return facettype.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_TOPLAYER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
71 facettype.equals(FacetTypes.BED_QUALITY_BED_DIAMETER_SUBLAYER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
72 facettype.equals(FacetTypes.BED_QUALITY_BEDLOAD_DIAMETER) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
73 facettype.equals(FacetTypes.BED_DIAMETER_DATA_TOP) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
74 facettype.equals(FacetTypes.BED_DIAMETER_DATA_SUB) ||
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
75 facettype.equals(FacetTypes.BEDLOAD_DIAMETER_DATA);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
76 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
77
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
78 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
79 public String getAxisLabel(DiagramGenerator generator) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
80 return generator.msg(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
81 I18N_AXIS_LABEL,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
82 I18N_AXIS_LABEL_DEFAULT);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
83 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
84 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
85

http://dive4elements.wald.intevation.org