Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/MainValuesQFacet.java @ 2240:e9173de1026c
The HistoricalDischargeCurveGenerator now creates new AxisDataset objects and new TimeSeriesCollections for each Facet.
flys-artifacts/trunk@3887 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Thu, 02 Feb 2012 16:39:50 +0000 |
parents | 105097966111 |
children | 26f2e7e500dd |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import java.util.ArrayList; import java.util.List; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.artifactdatabase.state.DefaultFacet; import de.intevation.flys.artifacts.MainValuesArtifact; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.jfree.FLYSAnnotation; import de.intevation.flys.jfree.StickyAxisAnnotation; import de.intevation.flys.exports.DurationCurveGenerator; /** * Facet to show Main Q Values. * TODO Join with W implementation. */ public class MainValuesQFacet extends DefaultFacet implements FacetTypes { /** Do we want MainValues at Gauge (not interpolated)? */ protected boolean isAtGauge; /** Trivial Constructor. */ public MainValuesQFacet(String name, String description, boolean atGauge) { this.description = description; this.name = name; this.index = 0; this.isAtGauge = atGauge; } /** * Returns the data this facet requires. * * @param artifact the owner artifact. * @param context the CallContext (ignored). * * @return the data. */ @Override public Object getData(Artifact artifact, CallContext context) { MainValuesArtifact mvArtifact = (MainValuesArtifact) artifact; List<NamedDouble> qs = mvArtifact.getMainValuesQ(isAtGauge); List<StickyAxisAnnotation> xy = new ArrayList<StickyAxisAnnotation>(); // Rather specific case, Q-Annotations at a maybe second yaxis. if (this.name.equals(DURATION_MAINVALUES_Q)) { for (NamedDouble q: qs) { xy.add(new StickyAxisAnnotation( q.getName(), (float) q.getValue(), StickyAxisAnnotation.SimpleAxis.Y_AXIS, DurationCurveGenerator.YAXIS.Q.idx)); } } else { for (NamedDouble q: qs) { xy.add(new StickyAxisAnnotation( q.getName(), (float) q.getValue(), StickyAxisAnnotation.SimpleAxis.X_AXIS)); } } return new FLYSAnnotation(description, xy); } /** * Create a deep copy of this Facet. * @return a deep copy. */ @Override public MainValuesQFacet deepCopy() { MainValuesQFacet copy = new MainValuesQFacet(this.name, description, this.isAtGauge); copy.set(this); return copy; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :