annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/common/FlowDepthDevelopmentProcessor.java @ 8956:ee5ce13016ed

Work on SINFO-Fließtiefenentwicklung
author gernotbelger
date Tue, 20 Mar 2018 13:30:07 +0100
parents
children b194fa64506a
rev   line source
8956
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
2 * Software engineering by
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
5 *
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
9 */
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
10
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
11 package org.dive4elements.river.artifacts.sinfo.common;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
12
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
13 import java.util.HashSet;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
14 import java.util.Set;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
15
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
16 import org.dive4elements.artifactdatabase.state.Facet;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
17 import org.dive4elements.artifacts.CallContext;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.resources.Resources;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType;
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
20
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
21 public final class FlowDepthDevelopmentProcessor extends AbstractSInfoLineProcessor<AbstractSInfoCalculationResult> {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
22
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
23 private static final String I18N_AXIS_LABEL = "sinfo.chart.flow_depth_development.section.yaxis.label";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
24
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
25 private static final String SINFO_CHART_FLOW_DEPTH_DEVELOPMENT_YAXIS_LABEL = "sinfo.chart.flow_depth.yaxis.label";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
26
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
27 /* Theme name, usually defined in 'FacetTypes', but that is soooo bad dependencies... */
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
28 // REMARK: these mustend with 'filtered' so extra handling happens in chart: point are always recalculated, because data
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
29 // changes depending on zoom state
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
30 public static final String FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED = "sinfo_facet_flow_depth_development.filtered";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
31
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
32 private static final String I18N_FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED_DESCRIPTION = "sinfo.facet.flow_depth_development.filtered.description";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
33
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
34 public static final String FACET_WATERLEVEL_DIFFERENCE_FILTERED = "sinfo_facet_waterlevel_difference.filtered";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
35
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
36 private static final String I18N_FACET_WATERLEVEL_DIFFERENCE_FILTERED_DESCRIPTION = "sinfo.facet.waterlevel_difference.filtered.description";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
37
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
38 public static final String FACET_BEDHEIGHT_DIFFERENCE_FILTERED = "sinfo_facet_bedheight_difference.filtered";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
39
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
40 private static final String I18N_FACET_BEDHEIGHT_DIFFERENCE_FILTERED_DESCRIPTION = "sinfo.facet.bedheight_difference.filtered.description";
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
41
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
42 private static final Set<String> HANDLED_FACET_TYPES = new HashSet<>();
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
43
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
44 static {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
45 HANDLED_FACET_TYPES.add(FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
46 HANDLED_FACET_TYPES.add(FACET_WATERLEVEL_DIFFERENCE_FILTERED);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
47 HANDLED_FACET_TYPES.add(FACET_BEDHEIGHT_DIFFERENCE_FILTERED);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
48 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
49
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
50 public FlowDepthDevelopmentProcessor() {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
51 super(I18N_AXIS_LABEL, HANDLED_FACET_TYPES);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
52 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
53
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
54 @Override
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
55 protected double[][] doGetPoints(final AbstractSInfoCalculationResult data, final String facetName) {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
56
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
57 if (FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED.contentEquals(facetName))
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
58 return data.getStationPoints(SInfoResultType.flowdepthDevelopment);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
59
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
60 if (FACET_WATERLEVEL_DIFFERENCE_FILTERED.contentEquals(facetName))
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
61 return data.getStationPoints(SInfoResultType.waterlevelDifference);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
62
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
63 if (FACET_BEDHEIGHT_DIFFERENCE_FILTERED.contentEquals(facetName))
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
64 return data.getStationPoints(SInfoResultType.bedHeightDifference);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
65
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
66 final String error = String.format("Unknown facet name: %s", facetName);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
67 throw new UnsupportedOperationException(error);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
68 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
69
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
70 public static Facet createFlowDepthDevelopmentFacet(final CallContext context, final String hash, final String id,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
71 final AbstractSInfoCalculationResult result, final int index) {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
72 final String facetFlowDepthFilteredDescription = Resources.getMsg(context.getMeta(), I18N_FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED_DESCRIPTION,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
73 I18N_FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED_DESCRIPTION, result.getLabel());
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
74 return new SInfoResultFacet(index, FACET_FLOW_DEPTH_DEVELOPMENT_FILTERED, facetFlowDepthFilteredDescription,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
75 SINFO_CHART_FLOW_DEPTH_DEVELOPMENT_YAXIS_LABEL, ComputeType.ADVANCE, id, hash);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
76 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
77
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
78 public static Facet createWaterlevelDifferenceFacet(final CallContext context, final String hash, final String id,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
79 final AbstractSInfoCalculationResult result, final int index) {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
80 final String facetFlowDepthTkhFilteredDescription = Resources.getMsg(context.getMeta(), I18N_FACET_WATERLEVEL_DIFFERENCE_FILTERED_DESCRIPTION,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
81 I18N_FACET_WATERLEVEL_DIFFERENCE_FILTERED_DESCRIPTION, result.getLabel());
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
82 return new SInfoResultFacet(index, FACET_WATERLEVEL_DIFFERENCE_FILTERED, facetFlowDepthTkhFilteredDescription,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
83 SINFO_CHART_FLOW_DEPTH_DEVELOPMENT_YAXIS_LABEL, ComputeType.ADVANCE, id, hash);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
84 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
85
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
86 public static Facet createBedHeightDifferenceFacet(final CallContext context, final String hash, final String id,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
87 final AbstractSInfoCalculationResult result, final int index) {
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
88
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
89 final String facetFlowDepthFilteredDescription = Resources.getMsg(context.getMeta(), I18N_FACET_BEDHEIGHT_DIFFERENCE_FILTERED_DESCRIPTION,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
90 I18N_FACET_BEDHEIGHT_DIFFERENCE_FILTERED_DESCRIPTION, result.getLabel());
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
91 return new SInfoResultFacet(index, FACET_BEDHEIGHT_DIFFERENCE_FILTERED, facetFlowDepthFilteredDescription,
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
92 SINFO_CHART_FLOW_DEPTH_DEVELOPMENT_YAXIS_LABEL, ComputeType.ADVANCE, id, hash);
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
93 }
ee5ce13016ed Work on SINFO-Fließtiefenentwicklung
gernotbelger
parents:
diff changeset
94 }

http://dive4elements.wald.intevation.org