Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/exports/ChartHelper.java @ 3785:a5f65e8983be
Merged revisions 5501-5502,5504-5508,5511-5513,5516-5519 via svnmerge from
file:///home/clients/bsh/bsh-generischer-viewer/Material/SVN/flys-artifacts/trunk
........
r5501 | felix | 2012-09-18 11:49:45 +0200 (Di, 18 Sep 2012) | 1 line
fix issue865 - missing showarea theme prop.
........
r5502 | clins | 2012-09-18 12:18:30 +0200 (Di, 18 Sep 2012) | 1 line
Add robustness checks to prevent NPEs
........
r5504 | felix | 2012-09-18 14:03:15 +0200 (Di, 18 Sep 2012) | 1 line
i18n for area label (fix issue487).
........
r5505 | clins | 2012-09-18 16:19:59 +0200 (Di, 18 Sep 2012) | 1 line
Update themes to show point descriptions
........
r5506 | rrenkert | 2012-09-18 17:00:30 +0200 (Di, 18 Sep 2012) | 3 lines
Removed incorrect characteristic diameter.
........
r5507 | rrenkert | 2012-09-18 17:03:20 +0200 (Di, 18 Sep 2012) | 3 lines
Fixed some stupid bugs in bed quality data factory and calculation.
........
r5508 | teichmann | 2012-09-18 17:45:49 +0200 (Di, 18 Sep 2012) | 1 line
The usual whitespace and import cleanups.
........
r5511 | teichmann | 2012-09-18 18:24:51 +0200 (Di, 18 Sep 2012) | 1 line
Use generics aware Collections.emptyList().
........
r5512 | teichmann | 2012-09-18 20:36:52 +0200 (Di, 18 Sep 2012) | 1 line
Some more little steps towards "Auslagerung extremer Wasserspiegellagen".
........
r5513 | clins | 2012-09-18 23:38:19 +0200 (Di, 18 Sep 2012) | 1 line
A and B facets of fix analyis are now deactivated by default
........
r5516 | bricks | 2012-09-19 10:45:51 +0200 (Mi, 19 Sep 2012) | 2 lines
Add the gauge station to the GaugeOverviewInfoService xml response
........
r5517 | rrenkert | 2012-09-19 10:50:23 +0200 (Mi, 19 Sep 2012) | 3 lines
Added CSV export to bed quality calculation.
........
r5518 | bricks | 2012-09-19 11:04:04 +0200 (Mi, 19 Sep 2012) | 2 lines
Fix date in changelog entry
........
r5519 | teichmann | 2012-09-19 11:17:14 +0200 (Mi, 19 Sep 2012) | 1 line
Removed trailing whitespace.
........
flys-artifacts/tags/2.9.1@5531 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Wed, 19 Sep 2012 14:58:31 +0000 |
parents | b2ea89a665bc |
children |
line wrap: on
line source
package de.intevation.flys.exports; import org.jfree.data.Range; import org.jfree.data.xy.XYDataset; import org.jfree.data.xy.XYSeriesCollection; import org.jfree.data.time.RegularTimePeriod; import org.jfree.data.time.TimeSeriesCollection; import org.jfree.data.time.TimeSeries; import org.apache.log4j.Logger; import de.intevation.flys.jfree.Bounds; import de.intevation.flys.jfree.DoubleBounds; import de.intevation.flys.jfree.TimeBounds; /** * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class ChartHelper { private static final Logger logger = Logger.getLogger(ChartHelper.class); /** * This method returns the ranges of the XYDataset <i>dataset</i> as array * with [xrange, yrange]. * * @param dataset The dataset which should be evaluated. * * @return an array with x and y ranges. */ public static Bounds[] getBounds(XYSeriesCollection dataset) { int seriesCount = dataset != null ? dataset.getSeriesCount() : 0; if (seriesCount == 0) { logger.warn("Dataset is empty or has no Series set."); return null; } boolean foundValue = false; double minX = Double.MAX_VALUE; double maxX = -Double.MAX_VALUE; double minY = Double.MAX_VALUE; double maxY = -Double.MAX_VALUE; for (int i = 0, m = seriesCount; i < m; i++) { for (int j = 0, n = dataset.getItemCount(i); j < n; j++) { double x = dataset.getXValue(i, j); double y = dataset.getYValue(i, j); if (Double.isNaN(x) || Double.isNaN(y)) { logger.warn("Item " + j + " in Series " + i + " is broken"); continue; } foundValue = true; if (x < minX) { minX = x; } if (x > maxX) { maxX = x; } if (y < minY) { minY = y; } if (y > maxY) { maxY = y; } } } return foundValue ? new Bounds[] { new DoubleBounds(minX, maxX), new DoubleBounds(minY, maxY) } : null; } public static Bounds[] getBounds(XYDataset dataset) { if (dataset instanceof XYSeriesCollection) { return getBounds((XYSeriesCollection) dataset); } else if(dataset instanceof TimeSeriesCollection) { return getBounds((TimeSeriesCollection) dataset); } else { logger.warn("Unknown XYDataset instance: " + dataset.getClass()); return null; } } public static Bounds[] getBounds(TimeSeriesCollection collection) { int seriesCount = collection != null ? collection.getSeriesCount() : 0; if (seriesCount == 0) { logger.warn("TimeSeriesCollection is empty or has no Series set."); return null; } boolean foundValue = false; long lowerX = Long.MAX_VALUE; long upperX = -Long.MAX_VALUE; double lowerY = Double.MAX_VALUE; double upperY = -Double.MAX_VALUE; for (int i = 0, m = seriesCount; i < m; i++) { TimeSeries series = collection.getSeries(i); for (int j = 0, n = collection.getItemCount(i); j < n; j++) { RegularTimePeriod rtp = series.getTimePeriod(j); if (rtp == null) { continue; } foundValue = true; long start = rtp.getFirstMillisecond(); long end = rtp.getLastMillisecond(); if (start < lowerX) { lowerX = start; } if (end > upperX) { upperX = end; } double y = series.getValue(j).doubleValue(); lowerY = Math.min(lowerY, y); upperY = Math.max(upperY, y); } } if (foundValue) { return new Bounds[] { new TimeBounds(lowerX, upperX), new DoubleBounds(lowerY, upperY) }; } return null; } /** * Expand bounds by percent. * * @param bounds The bounds to expand. * @param percent The percentage to expand. * * @return a new, expanded bounds. */ public static Bounds expandBounds(Bounds bounds, double percent) { if (bounds == null) { return null; } double value = (Double) bounds.getLower(); double expand = Math.abs(value / 100 * percent); return expand != 0 ? new DoubleBounds(value-expand, value+expand) : new DoubleBounds(-0.01 * percent, 0.01 * percent); } /** * Expand range by percent. * * @param range The range to expand. * @param percent The percentage to expand. * * @return a new, expanded range. */ public static Range expandRange(Range range, double percent) { if (range == null) { return null; } double value = range.getLowerBound(); double expand = Math.abs(value / 100 * percent); return expand != 0 ? new Range(value-expand, value+expand) : new Range(-0.01 * percent, 0.01 * percent); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :