annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedQualityPorosityProcessor.java @ 7892:e844be34a606 facet-metadata

Add metadata to chart series and datasets.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 21 May 2014 11:40:14 +0200
parents 693778752ee7
children 98ca61cb58fb
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
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
11 import java.util.Map;
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
12
7148
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.FacetTypes;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.exports.DiagramGenerator;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.exports.StyledSeriesBuilder;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.jfree.StyledXYSeries;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
22 import org.dive4elements.river.themes.ThemeDocument;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
23
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
24 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
25 import org.dive4elements.river.artifacts.model.minfo.Porosity;
7148
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 public class BedQualityPorosityProcessor extends DefaultProcessor {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
28
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
29 private final static Logger logger =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
30 Logger.getLogger(BedQualityPorosityProcessor.class);
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 public static final String I18N_AXIS_LABEL_DEFAULT =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
33 "Porosität [%]";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
34 public static final String I18N_AXIS_LABEL =
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
35 "chart.bedquality.yaxis.label.porosity";
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
36
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
37 protected String yAxisLabel;
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
38
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
39 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
40 public void doOut(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
41 DiagramGenerator generator,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
42 ArtifactAndFacet bundle,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
43 ThemeDocument theme,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
44 boolean visible) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
45 CallContext context = generator.getCallContext();
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
46 Map<String, String> metaData = bundle.getFacet().getMetaData();
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
47 StyledXYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
48 theme);
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
49 series.putMetaData(metaData, bundle.getArtifact(), context);
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
50 yAxisLabel = metaData.get("Y");
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
51 Object data = bundle.getData(context);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
52 String facetName = bundle.getFacetName();
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
53 double [][] points;
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
54
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
55 if (facetName.equals(FacetTypes.BED_QUALITY_POROSITY_TOPLAYER)) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
56 points = ((BedParametersResult) data).getPorosityCapData();
7724
c3a12d77c16b Fix doOut for Porosity sublayer
Andre Heinecke <aheinecke@intevation.de>
parents: 7159
diff changeset
57 } else if (facetName.equals(FacetTypes.BED_QUALITY_POROSITY_SUBLAYER)) {
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
58 points = ((BedParametersResult) data).getPorositySubData();
7848
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
59 } else if (facetName.equals(FacetTypes.POROSITY)) {
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
60 points = ((Porosity)data).getAsArray();
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
61 } else {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
62 logger.error("Unknown facet name: " + facetName);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
63 return;
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 StyledSeriesBuilder.addPoints(series, points, true);
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 generator.addAxisSeries(series, axisName, visible);
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 boolean canHandle(String facettype) {
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
72 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
73 facettype.equals(FacetTypes.BED_QUALITY_POROSITY_SUBLAYER) ||
693778752ee7 Handle porosity facets in a processor.
Raimund Renkert <rrenkert@intevation.de>
parents: 7724
diff changeset
74 facettype.equals(FacetTypes.POROSITY);
7148
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 @Override
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
78 public String getAxisLabel(DiagramGenerator generator) {
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
79 if (yAxisLabel != null && !yAxisLabel.isEmpty()) {
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
80 return generator.msg(yAxisLabel, I18N_AXIS_LABEL_DEFAULT);
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7848
diff changeset
81 }
7148
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
82 return generator.msg(
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
83 I18N_AXIS_LABEL,
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
84 I18N_AXIS_LABEL_DEFAULT);
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
85 }
cde7db30847f Add BedQuality Processors
Andre Heinecke <aheinecke@intevation.de>
parents:
diff changeset
86 }
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

http://dive4elements.wald.intevation.org