Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/CrossSectionWaterLineFacet.java @ 1996:c6432e8ea31e
Bugfix: add new Outputs during merge process in AttributeWriter.
flys-artifacts/trunk@3433 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Fri, 16 Dec 2011 10:25:55 +0000 |
parents | bf62cc7052d4 |
children | 98f3ef8da857 |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import org.apache.log4j.Logger; import java.util.List; import de.intevation.flys.model.CrossSectionLine; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.artifactdatabase.state.DefaultFacet; import de.intevation.artifactdatabase.state.Facet; import de.intevation.artifacts.DataProvider; import de.intevation.flys.artifacts.WaterLineArtifact; /** * Facet for Waterlines in Cross Sections. */ public class CrossSectionWaterLineFacet extends DefaultFacet implements FacetTypes { private static Logger logger = Logger.getLogger(CrossSectionWaterLineFacet.class); /** Trivial constructor, set (maybe localized) description. */ public CrossSectionWaterLineFacet(int idx, String description) { super(idx, CROSS_SECTION_WATER_LINE, description); } /** * Gets waterline (crossed with cross section) of waterlevel. */ public Object getData(Artifact artifact, CallContext context) { logger.debug("Get data for cross section water line"); List<DataProvider> providers = context. getDataProvider(CrossSectionFacet.BLACKBOARD_CS_MASTER_DATA); if (providers.size() < 1) { logger.warn("Could not find Cross-Section data provider."); return new double[][] {}; } Object crossSection = providers.get(0) .provideData(CrossSectionFacet.BLACKBOARD_CS_MASTER_DATA, null, context); WaterLineArtifact winfo = (WaterLineArtifact)artifact; return winfo.getWaterLines(this.getIndex(), (CrossSectionLine) crossSection); } /** Do a deep copy. */ @Override public Facet deepCopy() { CrossSectionWaterLineFacet copy = new CrossSectionWaterLineFacet( this.getIndex(), this.description); copy.set(this); return copy; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :