Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationState.java @ 9150:23945061daec
gigantic refactoring: exporter, result, results
to support multiple jaspers -> collisions
author | gernotbelger |
---|---|
date | Thu, 14 Jun 2018 16:56:31 +0200 |
parents | e6b63b2b41b9 |
children | 1614cb14308f |
rev | line source |
---|---|
9050 | 1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by Intevation GmbH | |
3 * | |
4 * This file is Free Software under the GNU AGPL (>=v3) | |
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
6 * documentation coming with Dive4Elements River for details. | |
7 */ | |
8 | |
9054
95643dffd006
rename grounding->collision; inundation_duration->flood_duration
gernotbelger
parents:
9050
diff
changeset
|
9 package org.dive4elements.river.artifacts.sinfo.flood_duration; |
9050 | 10 |
11 import java.util.List; | |
12 | |
13 import org.dive4elements.artifactdatabase.state.Facet; | |
14 import org.dive4elements.artifacts.CallContext; | |
15 import org.dive4elements.river.artifacts.ChartArtifact; | |
16 import org.dive4elements.river.artifacts.D4EArtifact; | |
9150
23945061daec
gigantic refactoring: exporter, result, results
gernotbelger
parents:
9145
diff
changeset
|
17 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult; |
9050 | 18 import org.dive4elements.river.artifacts.model.CalculationResult; |
9145 | 19 import org.dive4elements.river.artifacts.model.DataFacet; |
9050 | 20 import org.dive4elements.river.artifacts.model.EmptyFacet; |
9145 | 21 import org.dive4elements.river.artifacts.model.FacetTypes; |
9050 | 22 import org.dive4elements.river.artifacts.sinfo.SINFOArtifact; |
23 import org.dive4elements.river.artifacts.states.DefaultState; | |
24 | |
25 /** State in which a waterlevel has been calculated. */ | |
9054
95643dffd006
rename grounding->collision; inundation_duration->flood_duration
gernotbelger
parents:
9050
diff
changeset
|
26 public class FloodDurationState extends DefaultState { |
9050 | 27 |
28 /// ** The log that is used in this state. */ | |
29 // private static Logger log = Logger.getLogger(FlowDepthState.class); | |
30 | |
31 private static final long serialVersionUID = 1L; | |
32 | |
33 /** | |
34 * From this state can only be continued trivially. | |
35 */ | |
36 @Override | |
37 protected String getUIProvider() { | |
38 return "continue"; | |
39 } | |
40 | |
41 @Override | |
42 public Object computeFeed(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) { | |
43 if (artifact instanceof ChartArtifact) { | |
44 facets.add(new EmptyFacet()); | |
45 return null; | |
46 } | |
47 | |
48 return compute((SINFOArtifact) artifact, context, hash, facets, old); | |
49 } | |
50 | |
51 @Override | |
52 public Object computeAdvance(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) { | |
53 if (artifact instanceof ChartArtifact) { | |
54 facets.add(new EmptyFacet()); | |
55 return null; | |
56 } | |
57 return compute((SINFOArtifact) artifact, context, hash, facets, old); | |
58 } | |
59 | |
60 /** | |
61 * Compute result or returned object from cache, create facets. | |
62 * | |
63 * @param old | |
64 * Object that was cached. | |
65 */ | |
66 private Object compute(final SINFOArtifact sinfo, final CallContext context, final String hash, final List<Facet> facets, final Object old) { | |
67 | |
68 final CalculationResult res = doCompute(sinfo, context, old); | |
69 | |
70 if (facets == null) | |
71 return res; | |
72 | |
9145 | 73 final FloodDurationCalculationResults results = (FloodDurationCalculationResults) res.getData(); |
74 | |
75 /* add themes for chart, for each result */ | |
9150
23945061daec
gigantic refactoring: exporter, result, results
gernotbelger
parents:
9145
diff
changeset
|
76 final List<AbstractCalculationExportableResult<FloodDurationCalculationResults>> resultList = results.getResults(); |
9145 | 77 for (int index = 0; index < resultList.size(); index++) { |
78 | |
9150
23945061daec
gigantic refactoring: exporter, result, results
gernotbelger
parents:
9145
diff
changeset
|
79 final AbstractCalculationExportableResult<FloodDurationCalculationResults> result = resultList.get(0); |
9145 | 80 |
81 /* filtered (zoom dependent mean) flow depth TODO: */ | |
82 // facets.add(FloodDurationProcessor.createFlowDepthFilteredFacet(context, hash, this.id, result, index)); | |
83 // facets.add(FloodDurationProcessor.createFlowDepthRawFacet(context, hash, this.id, result, index)); | |
84 | |
85 } | |
86 | |
87 if (!resultList.isEmpty()) { | |
88 final Facet csv = new DataFacet(FacetTypes.CSV, "CSV data", ComputeType.ADVANCE, hash, this.id); | |
89 final Facet pdf = new DataFacet(FacetTypes.PDF, "PDF data", ComputeType.ADVANCE, hash, this.id); | |
90 | |
91 facets.add(csv); | |
92 facets.add(pdf); | |
93 } | |
94 | |
9050 | 95 // final Calculation report = res.getReport(); |
96 // | |
97 // if (report.hasProblems()) { | |
98 // facets.add(new ReportFacet(ComputeType.ADVANCE, hash, this.id)); | |
99 // } | |
100 | |
101 return res; | |
102 } | |
103 | |
104 private CalculationResult doCompute(final SINFOArtifact sinfo, final CallContext context, final Object old) { | |
105 if (old instanceof CalculationResult) | |
106 return (CalculationResult) old; | |
107 | |
9067 | 108 return new FloodDurationCalculation(context).calculate(sinfo); |
9050 | 109 } |
110 } |