changeset 4535:b838d16c629e

Refactor BedHeightArtifacts to provide bed height single values of a range The range of bed height single values is necessary to generate a chart for sounding widths.
author Björn Ricks <bjoern.ricks@intevation.de>
date Thu, 15 Nov 2012 16:20:02 +0100 (2012-11-15)
parents 1619f80eb62e
children ce4ff444f215
files flys-artifacts/src/main/java/de/intevation/flys/artifacts/BedHeightsArtifact.java
diffstat 1 files changed, 63 insertions(+), 32 deletions(-) [+]
line wrap: on
line diff
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/BedHeightsArtifact.java	Thu Nov 15 16:18:02 2012 +0100
+++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/BedHeightsArtifact.java	Thu Nov 15 16:20:02 2012 +0100
@@ -6,25 +6,29 @@
 import org.apache.log4j.Logger;
 import org.w3c.dom.Document;
 
+import de.intevation.artifactdatabase.state.DefaultOutput;
 import de.intevation.artifactdatabase.state.Facet;
 import de.intevation.artifactdatabase.state.FacetActivity;
-import de.intevation.artifactdatabase.state.State;
 import de.intevation.artifacts.ArtifactFactory;
+import de.intevation.artifacts.Artifact;
 import de.intevation.artifacts.CallMeta;
 import de.intevation.artifacts.common.utils.XMLUtils;
 import de.intevation.flys.artifacts.model.minfo.BedHeight;
 import de.intevation.flys.artifacts.model.minfo.BedHeightFacet;
 import de.intevation.flys.artifacts.model.minfo.BedHeightFactory;
 import de.intevation.flys.artifacts.states.StaticState;
+import de.intevation.flys.model.BedHeightSingle;
+import de.intevation.flys.model.BedHeightSingleValue;
 
 public class BedHeightsArtifact
-extends      StaticFLYSArtifact
+extends      AbstractStaticStateArtifact
 {
     /** The logger for this class. */
     private static Logger logger =
         Logger.getLogger(BedHeightsArtifact.class);
 
     private static final String NAME = "bedheights";
+    private static final String STATIC_FACET_NAME = "bedheight";
 
     static {
         // TODO: Move to configuration.
@@ -40,10 +44,6 @@
     public static final String DATA_HEIGHT_TYPE =
         "height_marks";
 
-    /** One and only state to be in. */
-    protected transient State state = null;
-
-
     /**
      * Trivial Constructor.
      */
@@ -69,53 +69,44 @@
     {
         logger.debug("BedHeightsArtifact.setup");
 
-        state = new StaticState(STATIC_STATE_NAME);
-
         if (logger.isDebugEnabled()) {
             logger.debug(XMLUtils.toString(data));
         }
 
-        List<Facet> fs = new ArrayList<Facet>();
         String code = getDatacageIDValue(data);
 
         if (code != null) {
             String [] parts = code.split("-");
 
             if (parts.length >= 4) {
-                if (parts[0].equals("bedheight")) {
-                    addStringData("type", parts[1]);
+                String name = parts[0];
+                String type = parts[1];
+                String btype = type;
+                int hId = Integer.parseInt(parts[2]);
+                if (name.equals("bedheight")) {
+                    addStringData("type", type);
                     addStringData("height_id", parts[2]);
                     addStringData("time", parts[3]);
                 }
-                int hId = Integer.parseInt(parts[2]);
-                String bedHName = BedHeightFactory.getHeightName(parts[1], hId);
+                if (type.equals("singlevalues")) {
+                    btype = "single";
+                }
 
-                Facet bedHFacet = new BedHeightFacet(
-                    "bedheight",
-                    bedHName);
+                String bedHName = BedHeightFactory.getHeightName(btype, hId);
 
-                fs.add(bedHFacet);
-                addFacets(state.getID(), fs);
+                Facet facet = new BedHeightFacet(
+                        STATIC_FACET_NAME, bedHName, type);
+
+                ArrayList<Facet> facets = new ArrayList<Facet>(1);
+                facets.add(facet);
+
+                addFacets(STATIC_STATE_NAME, facets);
             }
         }
-
-        //spawnState();
         super.setup(identifier, factory, context, callMeta, data);
     }
 
     /**
-     * Get a list containing the one and only State.
-     * @param  context ignored.
-     * @return list with one and only state.
-     */
-    @Override
-    protected List<State> getStates(Object context) {
-        ArrayList<State> states = new ArrayList<State>();
-        states.add(state);
-        return states;
-    }
-
-    /**
      */
     public BedHeight getHeight() {
         return BedHeightFactory.getHeight(
@@ -123,5 +114,45 @@
             Integer.parseInt(getDataAsString("height_id")),
             Integer.parseInt(getDataAsString("time")));
     }
+
+    public List<BedHeightSingleValue> getSingleValues() {
+        logger.debug("getSingleValues");
+        BedHeightSingle single = BedHeightSingle.getBedHeightSingleById(
+                getDataAsInteger("height_id"));
+        return BedHeightSingleValue.getBedHeightSingleValues(single,
+                getDataAsDouble("ld_from"),
+                getDataAsDouble("ld_to"));
+    }
+
+    @Override
+    protected void initStaticState() {
+
+        logger.debug("initStaticState " + getName() + " " + identifier());
+
+        StaticState state = new StaticState(STATIC_STATE_NAME);
+        DefaultOutput output = new DefaultOutput(
+                "general",
+                "general",
+                "image/png",
+                "chart");
+
+        List<Facet> facets = getFacets(STATIC_STATE_NAME);
+        output.addFacets(facets);
+        state.addOutput(output);
+
+        setStaticState(state);
+    }
+
+    @Override
+    protected void initialize(Artifact artifact, Object context, CallMeta meta) {
+        // do not clone facets, etc. from master artifact
+
+        logger.debug("initialize");
+        importData((FLYSArtifact)artifact, "ld_from");
+        importData((FLYSArtifact)artifact, "ld_to");
+
+        logger.debug("ld_from " + getDataAsString("ld_from"));
+        logger.debug("ld_to " + getDataAsString("ld_to"));
+    }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org