Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/common/SInfoResultFacet.java @ 9205:3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
author | gernotbelger |
---|---|
date | Mon, 02 Jul 2018 19:01:09 +0200 |
parents | b4402594213b |
children | 0fc9c82e744e |
rev | line source |
---|---|
8854 | 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 | |
8916 | 9 package org.dive4elements.river.artifacts.sinfo.common; |
8854 | 10 |
11 import org.apache.log4j.Logger; | |
12 import org.dive4elements.artifactdatabase.state.Facet; | |
13 import org.dive4elements.artifacts.Artifact; | |
14 import org.dive4elements.artifacts.CallContext; | |
15 import org.dive4elements.river.artifacts.D4EArtifact; | |
9166 | 16 import org.dive4elements.river.artifacts.common.AbstractCalculationResult; |
9170 | 17 import org.dive4elements.river.artifacts.common.AbstractCalculationResults; |
8854 | 18 import org.dive4elements.river.artifacts.model.CalculationResult; |
19 import org.dive4elements.river.artifacts.model.DataFacet; | |
20 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; | |
21 | |
22 /** | |
9202
b4402594213b
More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents:
9170
diff
changeset
|
23 * Facet of one of the S-Info curves. |
8854 | 24 */ |
8916 | 25 public final class SInfoResultFacet extends DataFacet { |
8854 | 26 |
8884 | 27 private static final long serialVersionUID = 1L; |
8854 | 28 |
8916 | 29 private static Logger log = Logger.getLogger(SInfoResultFacet.class); |
8884 | 30 |
9205
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
31 private int dataIndex; |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
32 |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
33 private int resultIndex; |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
34 |
8916 | 35 public SInfoResultFacet() { |
8854 | 36 // required for clone operation deepCopy() |
37 } | |
38 | |
9205
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
39 public SInfoResultFacet(final int resultIndex, final String name, final String description, final String yAxisLabelKey, final ComputeType type, |
9170 | 40 final String stateId, final String hash) { |
9205
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
41 // REMARK: |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
42 this(resultIndex, resultIndex, -1, name, description, yAxisLabelKey, type, stateId, hash); |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
43 } |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
44 |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
45 public SInfoResultFacet(final int resultIndex, final int dataIndex, final String name, final String description, final String yAxisLabelKey, |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
46 final ComputeType type, final String stateId, final String hash) { |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
47 // REMARK: in some cases, we have several |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
48 this(resultIndex, resultIndex, dataIndex, name, description, yAxisLabelKey, type, stateId, hash); |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
49 } |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
50 |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
51 public SInfoResultFacet(final int facetIndex, final int resultIndex, final int dataIndex, final String name, final String description, |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
52 // REMARK: in some cases, we have several data-lines for the same result (which normally determines the facet index) and |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
53 // facet name. But index and name are used by the client side as unique keys for the chart themes... |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
54 // So we might have different facet index and result index. |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
55 final String yAxisLabelKey, final ComputeType type, final String stateId, final String hash) { |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
56 super(facetIndex, name, description, type, hash, stateId); |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
57 this.resultIndex = resultIndex; |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
58 this.dataIndex = dataIndex; |
8916 | 59 this.metaData.put("X", "sinfo.chart.km.xaxis.label"); |
8884 | 60 this.metaData.put("Y", yAxisLabelKey); |
8854 | 61 } |
62 | |
9205
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
63 public int getDataIndex() { |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
64 return this.dataIndex; |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
65 } |
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
66 |
8854 | 67 @Override |
8884 | 68 public Object getData(final Artifact artifact, final CallContext context) { |
8916 | 69 log.debug("Get data for result at index: " + this.index); |
8854 | 70 |
71 final D4EArtifact flys = (D4EArtifact) artifact; | |
72 | |
8884 | 73 final CalculationResult res = (CalculationResult) flys.compute(context, this.hash, this.stateId, this.type, false); |
8854 | 74 |
9170 | 75 final AbstractCalculationResults<AbstractCalculationResult> data = (AbstractCalculationResults<AbstractCalculationResult>) res.getData(); |
8884 | 76 |
9205
3dae6b78e1da
inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents:
9202
diff
changeset
|
77 return data.getResults().get(this.resultIndex); |
8854 | 78 } |
79 | |
80 /** Copy deeply. */ | |
81 @Override | |
82 public Facet deepCopy() { | |
8891 | 83 // FIXME: why not simply use the full constructor instead? |
8916 | 84 final SInfoResultFacet copy = new SInfoResultFacet(); |
8854 | 85 // FIXME: why does DataFacet does not override set? Bad access to variables of parent! |
86 copy.set(this); | |
8884 | 87 copy.type = this.type; |
88 copy.hash = this.hash; | |
89 copy.stateId = this.stateId; | |
8854 | 90 return copy; |
91 } | |
92 } |