annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/inundationduration/InundationDurationState.java @ 9537:bf6b63208f34

Work on uinfo inundation duration calculation. Using proxy-wms to induce additional style information (work in progress).
author gernotbelger
date Wed, 17 Oct 2018 11:23:17 +0200
parents 992c188b7330
children 3955ecc1a516
rev   line source
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8996
diff changeset
2 * Software engineering by
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8996
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
5 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
9 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.uinfo.inundationduration;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
11
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
12 import java.util.List;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
13
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.Facet;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
15 import org.dive4elements.artifacts.CallContext;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.ChartArtifact;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.D4EArtifact;
9178
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
18 import org.dive4elements.river.artifacts.MapArtifact.MapState;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.model.Calculation;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.model.CalculationResult;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.model.DataFacet;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
22 import org.dive4elements.river.artifacts.model.EmptyFacet;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
23 import org.dive4elements.river.artifacts.model.ReportFacet;
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
24 import org.dive4elements.river.artifacts.model.map.WMSLayerFacet;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
25 import org.dive4elements.river.artifacts.uinfo.UINFOArtifact;
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
26 import org.dive4elements.river.artifacts.uinfo.inundationduration.InundationDurationCalculationResult.WmsLayer;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
27
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
28 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
29 * @author Domenico Nardi Tironi
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
30 */
9178
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
31 public class InundationDurationState extends MapState {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
32
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
33 /// ** The log that is used in this state. */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
34 // private static Logger log = Logger.getLogger(FlowDepthState.class);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
35
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
36 private static final long serialVersionUID = 1L;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
37
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
38 private static final String LABEL_URL_SEPARATOR = ";LABEL_URL_SEPARATOR;";// always sync with client (ExportPanel)
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
39
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
40 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
41 * From this state can only be continued trivially.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
42 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
43 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
44 protected String getUIProvider() {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
45 return "continue";
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
46 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
47
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
48 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
49 public Object computeFeed(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
50 // FIXME: why is this necessary?
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
51 if (artifact instanceof ChartArtifact) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
52 facets.add(new EmptyFacet());
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
53 return null;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
54 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
55
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
56 return compute((UINFOArtifact) artifact, context, ComputeType.FEED, hash, facets, old);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
57 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
58
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
59 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
60 public Object computeAdvance(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
61 if (artifact instanceof ChartArtifact) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
62 facets.add(new EmptyFacet());
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
63 return null;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
64 }
9178
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
65
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
66 if (facets != null)
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
67 super.computeAdvance(artifact, hash, context, facets, old);
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
68
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
69 return compute((UINFOArtifact) artifact, context, ComputeType.ADVANCE, hash, facets, old);
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
70
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
71 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
72
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
73 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
74 * Compute result or returned object from cache, create facets.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
75 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
76 * @param old
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
77 * Object that was cached.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
78 */
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
79 private Object compute(final UINFOArtifact sinfo, final CallContext context, final ComputeType type, final String hash, final List<Facet> facets,
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
80 final Object old) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
81
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
82 final CalculationResult res = doCompute(sinfo, context, old);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
83
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
84 if (facets == null)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
85 return res;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
86
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
87 final InundationDurationCalculationResult result = (InundationDurationCalculationResult) res.getData();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
88 final List<WmsLayer> layers = result.getLayers();
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
89
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
90 int index = 1; // 1 because super.computeAdvance adds the river theme with index 0
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
91 for (final WmsLayer layer : layers) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
92
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
93 final String label = layer.getLabel();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
94 final String url = layer.getUrl();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
95
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
96 final WMSLayerFacet wmsFacet = new WMSLayerFacet(index, FLOODMAP_EXTERNAL_WMS_INUNDATIONDUR + index, label, type, getID(), hash, url);
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
97 wmsFacet.addLayer(layer.getLayer());
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
98
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
99 facets.add(wmsFacet);
9483
992c188b7330 wms uinfo.inundation
gernotbelger
parents: 9481
diff changeset
100 // TODO:
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
101 // wmsFacet.setExtent(getExtent(false));
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
102 // wmsFacet.setOriginalExtent(getExtent(true));
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
103 wmsFacet.setSrid(getSrid());
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
104
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
105 if (layer.isShowLayerLink())
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
106 facets.add(new DataFacet("wms_url", label + LABEL_URL_SEPARATOR + url, ComputeType.ADVANCE, hash, this.id));
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
107
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
108 index++; // because super.computeAdvance adds the river theme with index 0
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
109 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
110
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
111 final Calculation report = res.getReport();
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
112 if (report.hasProblems())
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
113 facets.add(new ReportFacet(ComputeType.ADVANCE, hash, this.id));
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
114
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
115 return res;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
116 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
117
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
118 private CalculationResult doCompute(final UINFOArtifact artifact, final CallContext context, final Object old) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
119 if (old instanceof CalculationResult)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
120 return (CalculationResult) old;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
121
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
122 return new InundationDurationCalculation(context).calculate(artifact);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
123 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
124 }

http://dive4elements.wald.intevation.org