Mercurial > dive4elements > river
view artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkh/TkhState.java @ 8914:e3519c3e7a0a
Workflow for SINFO-Transport bodies heights inclduing winfo calculation
author | gernotbelger |
---|---|
date | Tue, 27 Feb 2018 18:06:52 +0100 |
parents | |
children |
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde * Software engineering by Intevation GmbH * * This file is Free Software under the GNU AGPL (>=v3) * and comes with ABSOLUTELY NO WARRANTY! Check out the * documentation coming with Dive4Elements River for details. */ package org.dive4elements.river.artifacts.sinfo.tkh; import java.util.List; import org.dive4elements.artifactdatabase.state.Facet; import org.dive4elements.artifacts.CallContext; import org.dive4elements.river.artifacts.ChartArtifact; import org.dive4elements.river.artifacts.D4EArtifact; import org.dive4elements.river.artifacts.WINFOArtifact; import org.dive4elements.river.artifacts.model.Calculation; import org.dive4elements.river.artifacts.model.CalculationResult; import org.dive4elements.river.artifacts.model.EmptyFacet; import org.dive4elements.river.artifacts.model.WQKms; import org.dive4elements.river.artifacts.sinfo.SINFOArtifact; import org.dive4elements.river.artifacts.states.DefaultState; /** State in which a waterlevel has been calculated. */ public class TkhState extends DefaultState { /// ** The log that is used in this state. */ // private static Logger log = Logger.getLogger(FlowDepthState.class); private static final long serialVersionUID = 1L; private static final String I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION = "sinfo.facet.flow_depth.filtered.description"; private static final String I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION = "sinfo.facet.flow_depth.tkh.filtered.description"; private static final String I18N_FACET_TKH_DESCRIPTION = "sinfo.facet.tkh.description"; private static final String SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL = "sinfo.chart.flow_depth.yaxis.label"; private static final String SINFO_CHART_TKX_YAXIS_LABEL = "sinfo.chart.tkh.yaxis.label"; /** * From this state can only be continued trivially. */ @Override protected String getUIProvider() { return "continue"; } @Override public Object computeFeed(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) { // FIXME: why is this necessary? if (artifact instanceof ChartArtifact) { facets.add(new EmptyFacet()); return null; } return compute((SINFOArtifact) artifact, context, hash, facets, old); } @Override public Object computeAdvance(final D4EArtifact artifact, final String hash, final CallContext context, final List<Facet> facets, final Object old) { if (artifact instanceof ChartArtifact) { facets.add(new EmptyFacet()); return null; } return compute((SINFOArtifact) artifact, context, hash, facets, old); } /** * Compute result or returned object from cache, create facets. * * @param old * Object that was cached. */ private Object compute(final SINFOArtifact sinfo, final CallContext context, final String hash, final List<Facet> facets, final Object old) { final CalculationResult res = doCompute(sinfo, context, old); if (facets == null) return res; // final FlowDepthCalculationResults results = (FlowDepthCalculationResults) res.getData(); // // /* add themes for chart, for each result */ // final List<FlowDepthCalculationResult> resultList = results.getResults(); // for (int index = 0; index < resultList.size(); index++) { // // final FlowDepthCalculationResult result = resultList.get(index); // // /* filtered (zoom dependent mean) flow depth */ // final String facetFlowDepthFilteredDescription = Resources.getMsg(context.getMeta(), // I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION, // I18N_FACET_FLOW_DEPTH_FILTERED_DESCRIPTION, result.getLabel()); // facets.add(new FlowDepthFacet(index, FlowDepthProcessor.FACET_FLOW_DEPTH_FILTERED, facetFlowDepthFilteredDescription, // SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL, ComputeType.ADVANCE, this.id, hash)); // // if (results.isUseTkh()) { // /* filtered (zoom dependent mean) flow depth including tkh */ // final String facetFlowDepthTkhFilteredDescription = Resources.getMsg(context.getMeta(), // I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION, // I18N_FACET_FLOW_DEPTH_TKH_FILTERED_DESCRIPTION, result.getLabel()); // facets.add(new FlowDepthFacet(index, FlowDepthProcessor.FACET_FLOW_DEPTH_TKH_FILTERED, // facetFlowDepthTkhFilteredDescription, // SINFO_CHART_FLOW_DEPTH_YAXIS_LABEL, ComputeType.ADVANCE, this.id, hash)); // // // FIXME: add other themes // // - Streckenfavoriten // // // FIXME: // // - Gemittelte Linie der Fließtiefe mitsamt TKH // // - Transportkörperhöhen (oben/unten/schraffur) // final String facetTkhDescription = Resources.getMsg(context.getMeta(), I18N_FACET_TKH_DESCRIPTION, // I18N_FACET_TKH_DESCRIPTION, // result.getLabel()); // facets.add(new FlowDepthFacet(index, TkhProcessor.FACET_TKH, facetTkhDescription, SINFO_CHART_TKX_YAXIS_LABEL, // ComputeType.ADVANCE, this.id, // hash)); // } // // // FIXME: Datenkorbkonfiguration // } // // if (!resultList.isEmpty()) { // final Facet csv = new DataFacet(FacetTypes.CSV, "CSV data", ComputeType.ADVANCE, hash, this.id); // final Facet pdf = new DataFacet(FacetTypes.PDF, "PDF data", ComputeType.ADVANCE, hash, this.id); // // facets.add(csv); // facets.add(pdf); // } // // final Calculation report = res.getReport(); // // if (report.hasProblems()) { // facets.add(new ReportFacet(ComputeType.ADVANCE, hash, this.id)); // } // // return res; return null; } private CalculationResult doCompute(final SINFOArtifact sinfo, final CallContext context, final Object old) { if (old instanceof CalculationResult) return (CalculationResult) old; // res = new FlowDepthCalculation(context).calculate(sinfo); final WINFOArtifact winfo = new WinfoArtifactWrapper(sinfo); final CalculationResult waterlevelData = winfo.getWaterlevelData(context); final Calculation winfoProblems = waterlevelData.getReport(); final WQKms[] kms = (WQKms[]) waterlevelData.getData(); final Object result = new Object(); final Calculation problems = new Calculation(); return new CalculationResult(result, problems); } }