annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedQualityPorosityProcessor.java @ 7848:693778752ee7

Handle porosity facets in a processor.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 30 Apr 2014 15:22:27 +0200
parents c3a12d77c16b
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.BedParametersResult;
7848
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
23 import org.dive4elements.river.artifacts.model.minfo.Porosity;
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
24
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
25 public class BedQualityPorosityProcessor extends DefaultProcessor {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
26
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
27 private final static Logger logger =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
28 Logger.getLogger(BedQualityPorosityProcessor.class);
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 static final String I18N_AXIS_LABEL_DEFAULT =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
31 "Porosität [%]";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
32 public static final String I18N_AXIS_LABEL =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
33 "chart.bedquality.yaxis.label.porosity";
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 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
36 public void doOut(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
37 DiagramGenerator generator,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
38 ArtifactAndFacet bundle,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
39 ThemeDocument theme,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
40 boolean visible) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
41 CallContext context = generator.getCallContext();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
42 XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
43 theme);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
44 Object data = bundle.getData(context);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
45 String facetName = bundle.getFacetName();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
46 double [][] points;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
47
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
48 if (facetName.equals(FacetTypes.BED_QUALITY_POROSITY_TOPLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
49 points = ((BedParametersResult) data).getPorosityCapData();
7724
c3a12d77c16b Fix doOut for Porosity sublayer
Andre Heinecke <aheinecke@intevation.de>
parents: 7159
diff changeset
50 } else if (facetName.equals(FacetTypes.BED_QUALITY_POROSITY_SUBLAYER)) {
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
51 points = ((BedParametersResult) data).getPorositySubData();
7848
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
52 } else if (facetName.equals(FacetTypes.POROSITY)) {
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
53 points = ((Porosity)data).getAsArray();
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
54 } else {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
55 logger.error("Unknown facet name: " + facetName);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
56 return;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
57 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
58 StyledSeriesBuilder.addPoints(series, points, true);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
59
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
60 generator.addAxisSeries(series, axisName, visible);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
61 }
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 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
64 public boolean canHandle(String facettype) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
65 return facettype.equals(FacetTypes.BED_QUALITY_POROSITY_TOPLAYER) ||
7848
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
66 facettype.equals(FacetTypes.BED_QUALITY_POROSITY_SUBLAYER) ||
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
67 facettype.equals(FacetTypes.POROSITY);
7148
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
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
70 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
71 public String getAxisLabel(DiagramGenerator generator) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
72 return generator.msg(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
73 I18N_AXIS_LABEL,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
74 I18N_AXIS_LABEL_DEFAULT);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
75 }
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

http://dive4elements.wald.intevation.org