Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/WaterlevelInfoState.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 | 3bf86d01fa54 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.states; import java.util.List; import org.apache.log4j.Logger; import de.intevation.artifacts.CallContext; import de.intevation.artifacts.CallMeta; import de.intevation.artifactdatabase.state.Facet; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.WINFOArtifact; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.ReportFacet; import de.intevation.flys.artifacts.model.WaterlevelFacet; import de.intevation.flys.artifacts.model.WQKms; import de.intevation.flys.artifacts.model.DataFacet; import de.intevation.flys.artifacts.model.CrossSectionWaterLineFacet; import de.intevation.flys.artifacts.model.CalculationResult; public class WaterlevelInfoState extends DefaultState implements FacetTypes { /** The logger that is used in this state. */ private static Logger logger = Logger.getLogger(WaterlevelInfoState.class); @Override protected String getUIProvider() { return "noinput"; } @Override public Object computeInit( FLYSArtifact artifact, String hash, Object context, CallMeta meta, List<Facet> facets ) { return compute((WINFOArtifact) artifact, hash, facets, null); } protected Object compute( WINFOArtifact winfo, String hash, List<Facet> facets, Object old ) { logger.debug("WaterlevelInfoState.compute"); String id = getID(); CalculationResult res = old instanceof CalculationResult ? (CalculationResult)old : winfo.getWaterlevelData(); if (facets == null) { return res; } WQKms [] wqkms = (WQKms [])res.getData(); for (int i = 0; i < wqkms.length; i++) { String nameW = null; String nameQ = null; if (winfo.isQ()) { nameQ = wqkms[i].getName(); nameW = "W(" + nameQ + ")"; } else { nameW = wqkms[i].getName(); nameQ = "Q(" + nameQ + ")"; } logger.debug("WaterlevelInfoState Create facet: " + nameW); logger.debug("WaterlevelInfoState Create facet: " + nameQ); Facet w = new WaterlevelFacet( i, LONGITUDINAL_W, nameW, ComputeType.ADVANCE, id, hash); Facet q = new WaterlevelFacet( i, LONGITUDINAL_Q, nameQ, ComputeType.ADVANCE, id, hash); facets.add(w); facets.add(q); } if (wqkms.length > 0) { Facet wst = new DataFacet( WST, "WST data", ComputeType.ADVANCE, hash, id); Facet csv = new DataFacet( CSV, "CSV data", ComputeType.ADVANCE, hash, id); facets.add(wst); facets.add(csv); } if (res.getReport().hasProblems()) { facets.add(new ReportFacet(ComputeType.ADVANCE, hash, id)); } // TODO Adjust to WaterlevelState - implementation. facets.add(new CrossSectionWaterLineFacet(0, "Q=" + winfo.getDataAsString("wq_single"))); // Assume to be in wq_single mode. return res; } /** * @param context Ignored. */ @Override public Object computeFeed( FLYSArtifact artifact, String hash, CallContext context, List<Facet> facets, Object old ) { return compute((WINFOArtifact) artifact, hash, facets, old); } /** * @param context Ignored. */ @Override public Object computeAdvance( FLYSArtifact artifact, String hash, CallContext context, List<Facet> facets, Object old ) { return compute((WINFOArtifact) artifact, hash, facets, old); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :