annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/inundationduration/InundationDurationState.java @ 9563:3955ecc1a516

Restrict inundation map to selected river range
author gernotbelger
date Mon, 29 Oct 2018 17:57:30 +0100
parents bf6b63208f34
children 63bbd5e45839
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;
9563
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
27 import org.dive4elements.river.model.RiverAxisKm;
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
28 import org.dive4elements.river.utils.GeometryUtils;
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
29
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
30 import com.vividsolutions.jts.geom.Envelope;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
31
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
32 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
33 * @author Domenico Nardi Tironi
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
34 */
9178
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
35 public class InundationDurationState extends MapState {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
36
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
37 /// ** The log that is used in this state. */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
38 // private static Logger log = Logger.getLogger(FlowDepthState.class);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
39
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
40 private static final long serialVersionUID = 1L;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
41
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
42 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
43
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
44 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
45 * From this state can only be continued trivially.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
46 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
47 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
48 protected String getUIProvider() {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
49 return "continue";
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
50 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
51
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
52 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
53 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
54 // FIXME: why is this necessary?
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
55 if (artifact instanceof ChartArtifact) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
56 facets.add(new EmptyFacet());
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
57 return null;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
58 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
59
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
60 return compute((UINFOArtifact) artifact, context, ComputeType.FEED, hash, facets, old);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
61 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
62
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
63 @Override
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
64 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
65 if (artifact instanceof ChartArtifact) {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
66 facets.add(new EmptyFacet());
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
67 return null;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
68 }
9178
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
69
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
70 if (facets != null)
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
71 super.computeAdvance(artifact, hash, context, facets, old);
2f5052835b76 uinfo inundationduration langjähr. Mittel, Uedauern.properties, Meldung
gernotbelger
parents: 9150
diff changeset
72
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
73 return compute((UINFOArtifact) artifact, context, ComputeType.ADVANCE, hash, facets, old);
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
74
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
75 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
76
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
77 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
78 * Compute result or returned object from cache, create facets.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
79 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
80 * @param old
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
81 * Object that was cached.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
82 */
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
83 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
84 final Object old) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
85
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
86 final CalculationResult res = doCompute(sinfo, context, old);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
87
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
88 if (facets == null)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
89 return res;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
90
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
91 final InundationDurationCalculationResult result = (InundationDurationCalculationResult) res.getData();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
92 final List<WmsLayer> layers = result.getLayers();
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
93
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
94 int index = 1; // 1 because super.computeAdvance adds the river theme with index 0
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
95 for (final WmsLayer layer : layers) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
96
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
97 final String label = layer.getLabel();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
98 final String url = layer.getUrl();
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
99
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
100 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
101 wmsFacet.addLayer(layer.getLayer());
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
102
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
103 facets.add(wmsFacet);
9483
992c188b7330 wms uinfo.inundation
gernotbelger
parents: 9481
diff changeset
104 // TODO:
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
105 // wmsFacet.setExtent(getExtent(false));
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
106 // wmsFacet.setOriginalExtent(getExtent(true));
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
107 wmsFacet.setSrid(getSrid());
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
108
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
109 if (layer.isShowLayerLink())
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
110 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
111
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
112 index++; // because super.computeAdvance adds the river theme with index 0
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
113 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
114
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
115 final Calculation report = res.getReport();
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
116 if (report.hasProblems())
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
117 facets.add(new ReportFacet(ComputeType.ADVANCE, hash, this.id));
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
118
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
119 return res;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
120 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
121
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
122 private CalculationResult doCompute(final UINFOArtifact artifact, final CallContext context, final Object old) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
123 if (old instanceof CalculationResult)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
124 return (CalculationResult) old;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
125
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9190
diff changeset
126 return new InundationDurationCalculation(context).calculate(artifact);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
127 }
9563
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
128
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
129 /**
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
130 * The extent is restricted to the selected station range
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
131 */
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
132 @Override
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
133 protected Envelope getExtent(final boolean reproject) {
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
134
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
135 final InundationDurationAccess access = new InundationDurationAccess((UINFOArtifact) this.artifact);
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
136
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
137 final double lowerKm = access.getLowerKm();
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
138 final double upperKm = access.getUpperKm();
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
139
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
140 final List<RiverAxisKm> axisKms = RiverAxisKm.getRiverAxisKms(getRiverId(), lowerKm, upperKm);
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
141
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
142 Envelope max = null;
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
143
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
144 for (final RiverAxisKm ax : axisKms) {
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
145 final Envelope env = ax.getGeom().getEnvelopeInternal();
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
146
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
147 if (max == null)
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
148 max = env;
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
149 else
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
150 max.expandToInclude(env);
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
151 }
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
152
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
153 return max != null && reproject ? GeometryUtils.transform(max, getSrid()) : max;
3955ecc1a516 Restrict inundation map to selected river range
gernotbelger
parents: 9537
diff changeset
154 }
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
155 }

http://dive4elements.wald.intevation.org