Mercurial > dive4elements > river
diff flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/FloodMapState.java @ 1119:faca1825818e
Write additional attributes ELEVATION and KILOMETER into crosssection track shapefiles.
flys-artifacts/trunk@2626 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Thu, 01 Sep 2011 07:04:01 +0000 |
parents | 7398280b11a0 |
children | fb3947027e92 |
line wrap: on
line diff
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/FloodMapState.java Wed Aug 31 13:19:29 2011 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/FloodMapState.java Thu Sep 01 07:04:01 2011 +0000 @@ -335,7 +335,7 @@ FeatureCollection polygons = FeatureCollections.newCollection(); for (SimpleFeature feature: f) { - Object geom = feature.getDefaultGeometry(); + Geometry geom = (Geometry) feature.getDefaultGeometry(); if (geom instanceof LineString) { lines.add(feature); @@ -405,8 +405,12 @@ logger.debug("Found " + cst.size() + " CrossSectionTracks."); + Object[][] attrs = new Object[2][]; + attrs[0] = new Object[] { "ELEVATION", Double.class }; + attrs[1] = new Object[] { "KILOMETER", Double.class }; + SimpleFeatureType ft = GeometryUtils.buildFeatureType( - "qps", srs, LineString.class); + "qps", srs, LineString.class, attrs); SimpleFeatureBuilder builder = new SimpleFeatureBuilder(ft); FeatureCollection collection = FeatureCollections.newCollection(); @@ -415,6 +419,8 @@ for (CrossSectionTrack track: cst) { builder.reset(); builder.add(track.getGeom()); + builder.add(track.getZ().doubleValue()); + builder.add(track.getKm().doubleValue()); collection.add(builder.buildFeature(String.valueOf(i++))); } @@ -424,7 +430,8 @@ try { GeometryUtils.writeShapefile( qpsShape, - GeometryUtils.buildFeatureType("qps", srs, LineString.class), + GeometryUtils.buildFeatureType( + "qps", srs, LineString.class, attrs), collection); job.setPro(qpsShape.getAbsolutePath()); }