tom@8858: /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde tom@8858: * Software engineering by Intevation GmbH tom@8858: * tom@8858: * This file is Free Software under the GNU AGPL (>=v3) tom@8858: * and comes with ABSOLUTELY NO WARRANTY! Check out the tom@8858: * documentation coming with Dive4Elements River for details. tom@8858: */ tom@8858: rrenkert@7985: package org.dive4elements.river.artifacts.model.minfo; rrenkert@7985: rrenkert@7985: import org.apache.log4j.Logger; rrenkert@7985: import org.dive4elements.artifactdatabase.state.Facet; rrenkert@7985: import org.dive4elements.artifacts.Artifact; rrenkert@7985: import org.dive4elements.artifacts.CallContext; tom@8273: tom@8559: import org.dive4elements.river.model.BedHeight; tom@8273: rrenkert@7985: import org.dive4elements.river.artifacts.D4EArtifact; tom@8273: import org.dive4elements.river.artifacts.access.RiverAccess; tom@8273: import org.dive4elements.river.artifacts.resources.Resources; rrenkert@7985: import org.dive4elements.river.artifacts.model.CalculationResult; rrenkert@7985: import org.dive4elements.river.artifacts.model.DataFacet; rrenkert@7985: import org.dive4elements.river.artifacts.model.FacetTypes; rrenkert@7985: import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; rrenkert@7985: rrenkert@7985: rrenkert@7985: public class BedDiffHeightSubFacet rrenkert@7985: extends DataFacet rrenkert@7985: implements FacetTypes rrenkert@7985: { teichmann@8202: private static Logger log = Logger.getLogger(BedDiffHeightSubFacet.class); rrenkert@7985: rrenkert@7985: public BedDiffHeightSubFacet() { rrenkert@7985: } rrenkert@7985: rrenkert@7985: public BedDiffHeightSubFacet(int idx, String name, String description, rrenkert@7985: ComputeType type, String stateId, String hash) { rrenkert@7985: super(idx, name, description, type, hash, stateId); rrenkert@7985: this.metaData.put("X", "chart.longitudinal.section.xaxis.label"); tom@8267: this.metaData.put("Y", "chart.bedheight_middle.section.yaxis.label"); rrenkert@7985: } rrenkert@7985: rrenkert@7985: public Object getData(Artifact artifact, CallContext context) { teichmann@8202: log.debug("Get data for bed density at index: " + index); rrenkert@7985: rrenkert@7985: D4EArtifact flys = (D4EArtifact) artifact; rrenkert@7985: rrenkert@7985: CalculationResult res = (CalculationResult) flys.compute(context, hash, rrenkert@7985: stateId, type, false); rrenkert@7985: rrenkert@7985: BedDiffYearResult[] resultData = rrenkert@7985: (BedDiffYearResult[]) res.getData(); // TODO CAST TO SPECIFIC CLASS rrenkert@7985: rrenkert@7985: if (resultData != null && resultData.length > index) { rrenkert@7985: BedDiffYearResult data = resultData[index]; tom@8273: tom@8559: BedHeight second = BedHeight.getBedHeightById( tom@8273: data.getIdSecond()); tom@8273: this.addMetaData(Resources.getMsg( tom@8273: context.getMeta(), tom@8273: "meta.bedheight.cur.elevation"), tom@8273: second.getCurElevationModel().getName()); tom@8332: if (second.getOldElevationModel() != null) { tom@8332: this.addMetaData(Resources.getMsg( tom@8332: context.getMeta(), tom@8332: "meta.bedheight.old.elevation"), tom@8332: second.getOldElevationModel().getName()); tom@8332: } tom@8273: this.addMetaData(Resources.getMsg( tom@8273: context.getMeta(), tom@8273: "meta.bedheight.river.elevation"), tom@8273: new RiverAccess(flys).getRiver().getWstUnit().getName()); tom@8273: rrenkert@7985: return data.getHeights2Data(); rrenkert@7985: } rrenkert@7985: return null; rrenkert@7985: } rrenkert@7985: rrenkert@7985: /** Copy deeply. */ rrenkert@7985: @Override rrenkert@7985: public Facet deepCopy() { rrenkert@7985: BedDiffHeightSubFacet copy = new BedDiffHeightSubFacet(); rrenkert@7985: copy.set(this); rrenkert@7985: copy.type = type; rrenkert@7985: copy.hash = hash; rrenkert@7985: copy.stateId = stateId; rrenkert@7985: return copy; rrenkert@7985: } rrenkert@7985: }