# HG changeset patch
# User Sascha L. Teichmann <sascha.teichmann@intevation.de>
# Date 1261561540 0
# Node ID 6a70e88833073d0c967e2800e1fc981107d021a0
# Parent  422275fc99278ffad1b28853866420c70e30b9cd
Added some type safety. Fixed z value bug in reading database preprocessing. Only dissemble WKT points if really needed.


gnv-artifacts/trunk@480 c6561f87-3c4e-4783-a992-168aeb5c3f6f

diff -r 422275fc9927 -r 6a70e8883307 gnv-artifacts/ChangeLog
--- a/gnv-artifacts/ChangeLog	Wed Dec 23 06:53:46 2009 +0000
+++ b/gnv-artifacts/ChangeLog	Wed Dec 23 09:45:40 2009 +0000
@@ -1,3 +1,20 @@
+2009-12-23	Sascha L. Teichmann	<sascha.teichmann@intevation.de>
+
+	* src/main/java/de/intevation/gnv/state/profile/verticalcrosssection/VerticalCrossSectionOutputState.java:
+	  When preprocessing database data only dissamble WKT points if we
+	  have to.
+	  Read z values as double value now.
+	  Commented out CSV export because it takes the database data
+	  as data which is not correct here. TODO: We need to implement some output 
+	  based on the interpolated data.
+	  Added some type safety to better match the 2D code.
+
+	* src/main/java/de/intevation/gnv/math/AttributedXYColumns.java: Stores
+	  XYColumns in ArrayList for better reused of the 2D code.
+
+	* src/main/java/de/intevation/gnv/math/XYColumn.java: Removed toArray()
+	  method because its not needed any longer.
+
 2009-12-23	Sascha L. Teichmann	<sascha.teichmann@intevation.de>
 
 	* src/main/java/de/intevation/gnv/math/XYColumn.java: Extends from
diff -r 422275fc9927 -r 6a70e8883307 gnv-artifacts/src/main/java/de/intevation/gnv/math/AttributedXYColumns.java
--- a/gnv-artifacts/src/main/java/de/intevation/gnv/math/AttributedXYColumns.java	Wed Dec 23 06:53:46 2009 +0000
+++ b/gnv-artifacts/src/main/java/de/intevation/gnv/math/AttributedXYColumns.java	Wed Dec 23 09:45:40 2009 +0000
@@ -2,22 +2,24 @@
 
 import java.util.Map;
 import java.util.HashMap;
+import java.util.List;
+
 import java.io.Serializable;
 
 public class AttributedXYColumns
 implements   Serializable
 {
-    protected XYColumn[] columns;
-    protected Map        attributes;
+    protected List<? extends XYColumn> columns;
+    protected Map                      attributes;
 
     public AttributedXYColumns() {
     }
 
-    public AttributedXYColumns(XYColumn[] columns) {
+    public AttributedXYColumns(List<? extends XYColumn> columns) {
         this(columns, null);
     }
 
-    public AttributedXYColumns(XYColumn[] columns, Map attributes) {
+    public AttributedXYColumns(List<? extends XYColumn> columns, Map attributes) {
         this.columns    = columns;
         this.attributes = attributes;
     }
@@ -27,17 +29,19 @@
     }
 
     public void setAttribute(Object key, Object value) {
-        if (attributes == null)
+        if (attributes == null) {
             attributes = new HashMap();
+        }
 
         attributes.put(key, value);
     }
 
-    public XYColumn[] getXYColumns() {
+    public List<? extends XYColumn> getXYColumns() {
         return columns;
     }
 
-    public void setXYColumns(XYColumn[] columns) {
+    public void setXYColumns(List<? extends XYColumn> columns) {
         this.columns = columns;
     }
 }
+// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8:
diff -r 422275fc9927 -r 6a70e8883307 gnv-artifacts/src/main/java/de/intevation/gnv/math/XYColumn.java
--- a/gnv-artifacts/src/main/java/de/intevation/gnv/math/XYColumn.java	Wed Dec 23 06:53:46 2009 +0000
+++ b/gnv-artifacts/src/main/java/de/intevation/gnv/math/XYColumn.java	Wed Dec 23 09:45:40 2009 +0000
@@ -10,7 +10,7 @@
 public class XYColumn
 extends      Point2d
 {
-    protected List values;
+    protected List<HeightValue> values;
 
     public XYColumn() {
     }
@@ -21,13 +21,13 @@
 
     public void add(HeightValue value) {
         if (values == null) {
-            values = new ArrayList();
+            values = new ArrayList<HeightValue>();
         }
         values.add(value);
     }
 
-    public HeightValue[] getValues() {
-        return (HeightValue[]) values.toArray(new HeightValue[values.size()]);
+    public List<HeightValue> getValues() {
+        return values;
     }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8:
diff -r 422275fc9927 -r 6a70e8883307 gnv-artifacts/src/main/java/de/intevation/gnv/state/profile/verticalcrosssection/VerticalCrossSectionOutputState.java
--- a/gnv-artifacts/src/main/java/de/intevation/gnv/state/profile/verticalcrosssection/VerticalCrossSectionOutputState.java	Wed Dec 23 06:53:46 2009 +0000
+++ b/gnv-artifacts/src/main/java/de/intevation/gnv/state/profile/verticalcrosssection/VerticalCrossSectionOutputState.java	Wed Dec 23 09:45:40 2009 +0000
@@ -7,18 +7,18 @@
 import java.io.OutputStream;
 import java.io.OutputStreamWriter;
 import java.io.UnsupportedEncodingException;
+
 import java.util.Collection;
 import java.util.HashMap;
 import java.util.Iterator;
 import java.util.Locale;
 import java.util.Map;
+import java.util.ArrayList;
 
 import org.apache.log4j.Logger;
 
 import org.jfree.chart.ChartTheme;
 
-import org.w3c.dom.Node;
-
 import net.sf.ehcache.Element;
 
 import au.com.bytecode.opencsv.CSVWriter;
@@ -29,14 +29,17 @@
 import com.vividsolutions.jts.io.ParseException;
 import com.vividsolutions.jts.io.WKTReader;
 
-import de.intevation.artifactdatabase.Config;
 import de.intevation.gnv.artifacts.cache.CacheFactory;
+
 import de.intevation.gnv.chart.Chart;
 import de.intevation.gnv.chart.ChartLabels;
 import de.intevation.gnv.chart.ChartStyle;
+
 import de.intevation.gnv.chart.exception.TechnicalChartException;
+
 import de.intevation.gnv.geobackend.base.Result;
 import de.intevation.gnv.geobackend.base.ResultDescriptor;
+
 import de.intevation.gnv.geobackend.base.query.QueryExecutor;
 import de.intevation.gnv.geobackend.base.query.QueryExecutorFactory;
 import de.intevation.gnv.geobackend.base.query.exception.QueryException;
@@ -49,8 +52,10 @@
 import de.intevation.gnv.state.describedata.KeyValueDescibeData;
 import de.intevation.gnv.state.exception.StateException;
 import de.intevation.gnv.state.timeseries.TimeSeriesOutputState;
+
 import de.intevation.gnv.statistics.Statistics;
 import de.intevation.gnv.statistics.VerticalProfileStatistics;
+
 import de.intevation.gnv.utils.WKTUtils;
 
 /**
@@ -158,8 +163,9 @@
 
 
     protected AttributedXYColumns preProcess(Collection results) {
+
         AttributedXYColumns attColumns = new AttributedXYColumns();
-        Map        map                 = new HashMap(1013);
+        Map<IJKey, XYColumn> map       = new HashMap<IJKey, XYColumn>(1013);
         Iterator   iter                = results.iterator();
 
         int sIdx = -1;
@@ -194,33 +200,27 @@
                 }
             }
 
-            try {
-                Point point  = (Point) new WKTReader().read(
-                    result.getString(sIdx));
-                double v     = result.getDouble(vIdx);
-                int i        = result.getInteger(iIdx);
-                int j        = result.getInteger(jIdx);
-                int k        = result.getInteger(kIdx);
-                int z        = result.getInteger(zIdx);
-
-                IJKey key = new IJKey(i, j);
+            double v = result.getDouble(vIdx);
+            double z = result.getDouble(zIdx);
+            int    i = result.getInteger(iIdx);
+            int    j = result.getInteger(jIdx);
+            int    k = result.getInteger(kIdx);
 
-                XYColumn col = (XYColumn)map.get(key);
+            IJKey key = new IJKey(i, j);
 
-                if (col == null) {
-                    col = new XYColumn(point.getX(), point.getY(), i, j);
-                    map.put(key, col);
-                }
+            XYColumn col = (XYColumn)map.get(key);
 
-                col.add(new HeightValue(z, v, k));
+            if (col == null) {
+                Coordinate coord = WKTUtils.toCoordinate(result.getString(sIdx));
+                if (coord == null) coord = new Coordinate();
+                col = new XYColumn(coord.x, coord.z, i, j);
+                map.put(key, col);
             }
-            catch (ParseException pe) {
-                log.warn("Error while parsing geometry.", pe);
-            }
+
+            col.add(new HeightValue(z, v, k));
         }
 
-        XYColumn[] cols = (XYColumn[])map.values().toArray(
-            new XYColumn[map.size()]);
+        ArrayList<XYColumn> cols = new ArrayList<XYColumn>(map.values());
         attColumns.setXYColumns(cols);
 
         return attColumns;
@@ -317,11 +317,13 @@
      * @see de.intevation.gnv.state.timeseries.TimeSeriesOutputState#createCSV(java.io.OutputStream, java.util.Collection)
      */
     @Override
-    protected void createCSV(OutputStream outputStream,
-                             Collection<Result> chartResult)
-                                                            throws UnsupportedEncodingException,
-                                                            IOException,
-                                                            StateException {
+    protected void createCSV(
+        OutputStream       outputStream,
+        Collection<Result> chartResult
+    )
+    throws UnsupportedEncodingException, IOException, StateException 
+    {
+        /* // TODO: Implement a substitution which makes sense.
         if (chartResult != null) {
             try {
                 CSVWriter writer = new CSVWriter(new OutputStreamWriter(
@@ -357,6 +359,7 @@
             throw new StateException(
                     "No Data given for generating an CSV-File.");
         }
+        */
     }
-
 }
+// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8: