Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/ReferenceCurveState.java @ 4241:49cb65d5932d
Improved the historical discharge calculation.
The calculation now creates new HistoricalWQKms (new subclass of WQKms). Those WQKms are used
to create new facets from (new) type 'HistoricalDischargeCurveFacet'. The chart generator is
improved to support those facets.
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Wed, 24 Oct 2012 14:34:35 +0200 |
parents | 23b4ff116015 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.states; import de.intevation.artifactdatabase.state.Facet; import de.intevation.artifacts.CallContext; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.WINFOArtifact; import de.intevation.flys.artifacts.model.CalculationResult; import de.intevation.flys.artifacts.model.DataFacet; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.ReferenceCurveFacet; import de.intevation.flys.artifacts.model.ReportFacet; import de.intevation.flys.artifacts.model.WWQQ; import java.util.List; import org.apache.log4j.Logger; /** State of WINFO in which reference curves can be produced. */ public class ReferenceCurveState extends DefaultState implements FacetTypes { private static Logger logger = Logger.getLogger(ReferenceCurveState.class); public ReferenceCurveState() { } @Override public Object computeAdvance( FLYSArtifact artifact, String hash, CallContext context, List<Facet> facets, Object old ) { if (!(artifact instanceof WINFOArtifact)) { return null; } String id = getID(); WINFOArtifact winfo = (WINFOArtifact)artifact; CalculationResult res = old instanceof CalculationResult ? (CalculationResult)old : winfo.getReferenceCurveData(context); if (facets == null) { return res; } WWQQ [] wws = (WWQQ [])res.getData(); for (int i = 0; i < wws.length; ++i) { String wwsName = wws[i].getName(); facets.add(new ReferenceCurveFacet(i, REFERENCE_CURVE, wwsName )); facets.add(new ReferenceCurveFacet(i, REFERENCE_CURVE_NORMALIZED, wwsName )); } if (wws.length > 0) { logger.debug("Adding CSV and PDF data facet."); Facet csv = new DataFacet (CSV, "CSV data", ComputeType.ADVANCE, hash, id); Facet pdf = new DataFacet (PDF, "PDF data", ComputeType.ADVANCE, hash, id); facets.add(csv); facets.add(pdf); } if (res.getReport().hasProblems()) { facets.add(new ReportFacet(ComputeType.ADVANCE, hash, id)); } return res; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :