annotate artifacts/src/main/java/org/dive4elements/river/exports/process/BedHeightProcessor.java @ 9617:1d4262a68f1f

#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
author dnt_bjoernsen <d.tironi@bjoernsen.de>
date Thu, 10 Oct 2019 15:29:02 +0200
parents 9b8e8fc1f408
children
rev   line source
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
2 * Software engineering by Intevation GmbH
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
3 *
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
7 */
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
8
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.exports.process;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
10
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7834
diff changeset
11 import java.util.Map;
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
12
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
15 import org.dive4elements.artifacts.CallContext;
8267
99912f51468d A bit less chaos in i18n for bed heights.
"Tom Gottfried <tom@intevation.de>"
parents: 8202
diff changeset
16 import org.dive4elements.artifacts.CallMeta;
7591
fab06617afb2 issue1225 Add i18n for bedheight and use wst height system as unit
Andre Heinecke <aheinecke@intevation.de>
parents: 7396
diff changeset
17 import org.dive4elements.river.artifacts.D4EArtifact;
8002
4366ec0d8f8f Removed unused imports and avoid using RiverUtils.
Raimund Renkert <rrenkert@intevation.de>
parents: 8001
diff changeset
18 import org.dive4elements.river.artifacts.access.RiverAccess;
7394
5eafd73312ae BedHeight(Sounding)Processor: Use FacetTypes.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7391
diff changeset
19 import org.dive4elements.river.artifacts.model.FacetTypes;
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
20 import org.dive4elements.river.artifacts.resources.Resources;
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
21 import org.dive4elements.river.exports.DiagramGenerator;
7705
f1257717fa4b (issue1594) Move Bed differences absolute height into the correct processor
Andre Heinecke <aheinecke@intevation.de>
parents: 7591
diff changeset
22 import org.dive4elements.river.exports.StyledSeriesBuilder;
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
23 import org.dive4elements.river.exports.XYChartGenerator;
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
24 import org.dive4elements.river.jfree.StyledXYSeries;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
25 import org.dive4elements.river.themes.ThemeDocument;
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
26 import org.jfree.data.xy.XYSeries;
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
27
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
28 public class BedHeightProcessor extends DefaultProcessor {
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
29
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
30 private final static Logger log = Logger.getLogger(BedHeightProcessor.class);
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
31
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
32 public static final String I18N_AXIS_LABEL = "chart.bedheight_middle.section.yaxis.label";
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
33
8961
8a1c6e2ad48b Implemented datacage for min/max bedheights.
gernotbelger
parents: 8856
diff changeset
34 public final static String FACET_BED_HEIGHTS_MIN = "bedheight_min";
8a1c6e2ad48b Implemented datacage for min/max bedheights.
gernotbelger
parents: 8856
diff changeset
35
8a1c6e2ad48b Implemented datacage for min/max bedheights.
gernotbelger
parents: 8856
diff changeset
36 public final static String FACET_BED_HEIGHTS_MAX = "bedheight_min";
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
37
7723
272cbcd94688 Make GAP_TOLERANCE static
Andre Heinecke <aheinecke@intevation.de>
parents: 7705
diff changeset
38 protected static final double GAP_TOLERANCE = 0.101d;
7705
f1257717fa4b (issue1594) Move Bed differences absolute height into the correct processor
Andre Heinecke <aheinecke@intevation.de>
parents: 7591
diff changeset
39
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7834
diff changeset
40 protected String yAxisLabel;
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7834
diff changeset
41
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
42 @Override
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
43 public void doOut(final DiagramGenerator generator, final ArtifactAndFacet bundle, final ThemeDocument theme, final boolean visible) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
44 final XYSeries series = prepareSeries(bundle, theme, generator.getContext());
7984
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
45 if (series != null) {
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
46 generator.addAxisSeries(series, this.axisName, visible);
7984
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
47 }
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
48 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
49
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
50 @Override
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
51 public void doOut(final XYChartGenerator generator, final ArtifactAndFacet bundle, final ThemeDocument theme, final boolean visible, final int index) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
52 final XYSeries series = prepareSeries(bundle, theme, generator.getContext());
7984
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
53 if (series != null) {
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
54 generator.addAxisSeries(series, index, visible);
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
55 }
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
56 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
57
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
58 /** Prepare an series, independent of axis. */
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
59 private XYSeries prepareSeries(final ArtifactAndFacet bundle, final ThemeDocument theme, final CallContext context) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
60 final Map<String, String> metaData = bundle.getFacet().getMetaData(bundle.getArtifact(), context);
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
61 final StyledXYSeries series = new StyledXYSeries(bundle.getFacetName(), bundle.getFacetDescription(), theme);
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7834
diff changeset
62 series.putMetaData(metaData, bundle.getArtifact(), context);
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
63 this.yAxisLabel = metaData.get("Y");
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
64
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
65 final Object raw = bundle.getData(context);
8001
5277483044d9 Fixed NPE when loading folders from datacage.
Raimund Renkert <rrenkert@intevation.de>
parents: 7984
diff changeset
66 if (raw == null) {
5277483044d9 Fixed NPE when loading folders from datacage.
Raimund Renkert <rrenkert@intevation.de>
parents: 7984
diff changeset
67 return null;
5277483044d9 Fixed NPE when loading folders from datacage.
Raimund Renkert <rrenkert@intevation.de>
parents: 7984
diff changeset
68 }
7984
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
69 if (!(raw instanceof double[][])) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 8002
diff changeset
70 log.error("Unkown datatype: " + raw.getClass().getName());
7984
cf674b03901a Bedheight facet now returns double[][]. Removed obsolete processor code.
Raimund Renkert <rrenkert@intevation.de>
parents: 7892
diff changeset
71 return null;
7705
f1257717fa4b (issue1594) Move Bed differences absolute height into the correct processor
Andre Heinecke <aheinecke@intevation.de>
parents: 7591
diff changeset
72 }
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
73
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
74 final double[][] data = (double[][]) raw;
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
75 StyledSeriesBuilder.addPoints(series, data, false, GAP_TOLERANCE);
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
76 return series;
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
77 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
78
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
79 @Override
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
80 public boolean canHandle(final String facetType) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
81 return FacetTypes.BEDHEIGHT.equals(facetType) || FACET_BED_HEIGHTS_MIN.equals(facetType) || FACET_BED_HEIGHTS_MAX.equals(facetType)
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
82 || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1.equals(facetType) || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT2.equals(facetType)
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
83 || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1_FILTERED.equals(facetType) || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT2_FILTERED.equals(facetType);
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
84 }
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
85
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
86 @Override
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
87 public String getAxisLabel(final DiagramGenerator generator) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
88 final D4EArtifact flys = (D4EArtifact) generator.getMaster();
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
89 final String unit = new RiverAccess(flys).getRiver().getWstUnit().getName();
7591
fab06617afb2 issue1225 Add i18n for bedheight and use wst height system as unit
Andre Heinecke <aheinecke@intevation.de>
parents: 7396
diff changeset
90
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
91 final CallMeta meta = generator.getContext().getMeta();
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
92
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
93 if (this.yAxisLabel != null && !this.yAxisLabel.isEmpty()) {
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
94 return Resources.getMsg(meta, this.yAxisLabel, new Object[] { unit });
7892
e844be34a606 Add metadata to chart series and datasets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7834
diff changeset
95 }
9617
1d4262a68f1f #12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9556
diff changeset
96 return Resources.getMsg(meta, I18N_AXIS_LABEL, new Object[] { unit });
7390
45e3bb00ce1a Stub for new BedHeightProcessor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
diff changeset
97 }
8961
8a1c6e2ad48b Implemented datacage for min/max bedheights.
gernotbelger
parents: 8856
diff changeset
98 }

http://dive4elements.wald.intevation.org