# HG changeset patch # User Felix Wolfsteller <felix.wolfsteller@intevation.de> # Date 1328108413 0 # Node ID 9dc81827b1877f91d6d7d8808c393b238da51a73 # Parent 4db19a88bddbbf456ffc3041882c475b7d33f030 Add some fake 'input' data for reference curve. plot references curves from input km to input km +2. flys-artifacts/trunk@3869 c6561f87-3c4e-4783-a992-168aeb5c3f6f diff -r 4db19a88bddb -r 9dc81827b187 flys-artifacts/ChangeLog --- a/flys-artifacts/ChangeLog Wed Feb 01 14:48:00 2012 +0000 +++ b/flys-artifacts/ChangeLog Wed Feb 01 15:00:13 2012 +0000 @@ -1,3 +1,17 @@ +2012-02-01 Felix Wolfsteller <felix.wolfsteller@intevation.de> + + Fake some reference curve input values to have working prototype + to work on. + + * src/main/java/de/intevation/flys/artifacts/WINFOArtifact.java: + Syntax-stunt fake reference inputs. + + * src/main/java/de/intevation/flys/artifacts/model/WW.java + (getW1): Accessor for first w at index (for the raw ww). + + * src/main/java/de/intevation/flys/exports/ReferenceCurveGenerator.java + (doReferenceOut): Plot the raw W-over-W. + 2012-02-01 Ingo Weinzierl <ingo@intevation.de> * src/main/java/de/intevation/flys/artifacts/WINFOArtifact.java: Create time diff -r 4db19a88bddb -r 9dc81827b187 flys-artifacts/src/main/java/de/intevation/flys/artifacts/WINFOArtifact.java --- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/WINFOArtifact.java Wed Feb 01 14:48:00 2012 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/WINFOArtifact.java Wed Feb 01 15:00:13 2012 +0000 @@ -649,6 +649,7 @@ return calc4.calculate(table, range[0], range[1], range[2]); } + /** * Returns the data that is computed by a reference curve computation. * @@ -683,7 +684,12 @@ return calc5.calculate(wst); } + protected Double getReferenceStartKm() { + if (true) { + return FLYSUtils.getLocations(this)[0]; + } + StateData sd = getData("reference_start"); if (sd == null) { @@ -709,8 +715,10 @@ } protected double [] getReferenceEndKms() { + StateData sd = getData("reference_end"); - StateData sd = getData("reference_end"); + if(true) + return new double[] {getReferenceStartKm() + 2.0d}; if (sd == null) { logger.warn("no reference end given."); diff -r 4db19a88bddb -r 9dc81827b187 flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/WW.java --- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/WW.java Wed Feb 01 14:48:00 2012 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/WW.java Wed Feb 01 15:00:13 2012 +0000 @@ -93,6 +93,10 @@ ws2.add(w2); } + public double getW1(int idx) { + return ws.getQuick(idx); + } + public double getW2(int idx) { return ws2.getQuick(idx); } diff -r 4db19a88bddb -r 9dc81827b187 flys-artifacts/src/main/java/de/intevation/flys/exports/ReferenceCurveGenerator.java --- a/flys-artifacts/src/main/java/de/intevation/flys/exports/ReferenceCurveGenerator.java Wed Feb 01 14:48:00 2012 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/exports/ReferenceCurveGenerator.java Wed Feb 01 15:00:13 2012 +0000 @@ -17,7 +17,7 @@ import de.intevation.artifactdatabase.state.ArtifactAndFacet; import de.intevation.flys.artifacts.model.FacetTypes; -import de.intevation.flys.artifacts.model.WQDay; +import de.intevation.flys.artifacts.model.WW; import de.intevation.flys.artifacts.resources.Resources; import de.intevation.flys.jfree.FLYSAnnotation; @@ -144,10 +144,17 @@ return label; } + + /** + * Called for each facet/them in the out mapped to this generator. + * @param artifactFacet artifact and facet for this theme. + * @param theme styling info. + * @param visible Whether or not the theme is visible. + */ @Override public void doOut( ArtifactAndFacet artifactFacet, - Document attr, + Document theme, boolean visible ) { String name = artifactFacet.getFacetName(); @@ -159,12 +166,9 @@ return; } - /* - if (name.equals(REFERENCE_W)) { - //doReference + if (name.equals(REFERENCE_CURVE)) { + doReferenceOut(artifactFacet.getData(context), theme, visible); } - */ - if (false) {} else { logger.warn("Unknown facet name: " + name); return; @@ -172,6 +176,24 @@ } + public void doReferenceOut( + Object data, + Document theme, + boolean visible + ){ + XYSeries series = new StyledXYSeries("TODO-RCG", theme); + + WW ww = (WW) (((WW.ApplyFunctionIterator)data).getWW()); + int size = ww.size(); + for (int i = 0; i < size; i++) { + series.add(ww.getW1(i), ww.getW2(i)); + } + + addAxisSeries(series, YAXIS.W.idx, visible); + } + + + /** Get Walker to iterate over all axes. */ @Override protected YAxisWalker getYAxisWalker() { return new YAxisWalker() {