teichmann@5863: /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde teichmann@5863: * Software engineering by Intevation GmbH teichmann@5863: * teichmann@5863: * This file is Free Software under the GNU AGPL (>=v3) teichmann@5863: * and comes with ABSOLUTELY NO WARRANTY! Check out the teichmann@5863: * documentation coming with Dive4Elements River for details. teichmann@5863: */ teichmann@5863: teichmann@5831: package org.dive4elements.river.artifacts.model.fixings; raimund@3039: teichmann@5831: import org.dive4elements.artifacts.Artifact; teichmann@5831: import org.dive4elements.artifacts.CallContext; sascha@3203: teichmann@5867: import org.dive4elements.river.artifacts.D4EArtifact; raimund@3039: teichmann@5831: import org.dive4elements.river.artifacts.access.FixAnalysisAccess; raimund@3039: teichmann@5831: import org.dive4elements.river.artifacts.model.CalculationResult; teichmann@5831: import org.dive4elements.river.artifacts.model.DateRange; teichmann@5831: import org.dive4elements.river.artifacts.model.FacetTypes; teichmann@5831: teichmann@5831: import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; teichmann@5831: teichmann@5831: import org.dive4elements.river.utils.KMIndex; sascha@3203: sascha@3203: import org.apache.log4j.Logger; raimund@3039: raimund@3039: /** raimund@3039: * Facet to show W values for Q values at km for a date. raimund@3039: * raimund@3039: * @author Raimund Renkert raimund@3039: */ raimund@3039: public class FixAnalysisPeriodsFacet bjoern@4442: extends FixingsFacet raimund@3039: implements FacetTypes { raimund@3039: raimund@3039: /** House logger. */ raimund@3039: private static Logger logger = Logger.getLogger(FixAnalysisPeriodsFacet.class); raimund@3039: raimund@3039: /** Trivial Constructor. */ raimund@3039: public FixAnalysisPeriodsFacet() { raimund@3039: } raimund@3039: raimund@3039: raimund@3039: /** raimund@3039: * @param name raimund@3039: */ raimund@3043: public FixAnalysisPeriodsFacet(int index, String name, String description) { raimund@3039: super(index, raimund@3043: name, raimund@3039: description, raimund@3039: ComputeType.ADVANCE, raimund@3039: null, raimund@3039: null); raimund@3039: } raimund@3039: raimund@3039: raimund@3039: /** raimund@3039: * Returns the data this facet requires. raimund@3039: * raimund@3039: * @param artifact the owner artifact. raimund@3039: * @param context the CallContext (ignored). raimund@3039: * raimund@3039: * @return the data. raimund@3039: */ raimund@3039: @Override raimund@3039: public Object getData(Artifact artifact, CallContext context) { raimund@3039: logger.debug("FixAnalysisPeriodsFacet.getData"); raimund@3039: teichmann@5867: if (artifact instanceof D4EArtifact) { teichmann@5867: D4EArtifact flys = (D4EArtifact)artifact; rrenkert@4866: FixAnalysisAccess access = new FixAnalysisAccess(flys, context); raimund@3039: raimund@3039: CalculationResult res = raimund@3039: (CalculationResult) flys.compute(context, raimund@3039: ComputeType.ADVANCE, raimund@3039: false); raimund@3039: sascha@3415: FixAnalysisResult result = (FixAnalysisResult) res.getData(); bjoern@4442: double currentKm = getCurrentKm(context); raimund@3039: raimund@3039: KMIndex kmPeriods = result.getAnalysisPeriods(); sascha@3076: KMIndex.Entry kmPeriodsEntry = raimund@3080: kmPeriods.binarySearch(currentKm); christian@3062: christian@3062: if (kmPeriodsEntry == null) { christian@3062: return null; christian@3062: } christian@3062: christian@3062: AnalysisPeriod[] periods = kmPeriodsEntry.getValue(); raimund@3039: raimund@3039: if (periods == null) { raimund@3039: return null; raimund@3039: } raimund@3039: DateRange[] dates = new DateRange[periods.length]; raimund@3039: for (int i = 0; i < periods.length; i++) { raimund@3039: dates[i] = periods[i].getDateRange(); raimund@3039: } raimund@3039: return dates; raimund@3039: } raimund@3039: else { raimund@3039: logger.debug("Not an instance of FixationArtifact."); raimund@3039: return null; raimund@3039: } raimund@3039: } raimund@3039: raimund@3039: raimund@3039: /** raimund@3039: * Create a deep copy of this Facet. raimund@3039: * @return a deep copy. raimund@3039: */ raimund@3039: @Override raimund@3039: public FixAnalysisPeriodsFacet deepCopy() { raimund@3039: FixAnalysisPeriodsFacet copy = new FixAnalysisPeriodsFacet(); raimund@3039: copy.set(this); raimund@3039: return copy; raimund@3039: } raimund@3039: } raimund@3039: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :