Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/exports/LongitudinalSectionGenerator.java @ 1688:7eb9015489b0
Worked on flys/issue150
flys-artifacts/trunk@2908 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Fri, 07 Oct 2011 15:55:38 +0000 |
parents | bdb05dc9b763 |
children | 0053a4529f2f |
line wrap: on
line source
package de.intevation.flys.exports; import org.apache.log4j.Logger; import org.jfree.chart.JFreeChart; import org.jfree.chart.axis.NumberAxis; import org.jfree.chart.axis.ValueAxis; import org.jfree.chart.plot.XYPlot; import org.jfree.chart.title.TextTitle; import org.jfree.data.Range; import org.jfree.data.xy.XYSeries; import org.w3c.dom.Document; import de.intevation.artifacts.Artifact; import de.intevation.artifactdatabase.state.Facet; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.model.FacetTypes; import de.intevation.flys.artifacts.model.WQKms; import de.intevation.flys.jfree.FLYSAnnotation; import de.intevation.flys.utils.FLYSUtils; import de.intevation.flys.utils.DataUtil; /** * An OutGenerator that generates discharge curves. * * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class LongitudinalSectionGenerator extends XYChartGenerator implements FacetTypes { /** The logger that is used in this generator. */ private static Logger logger = Logger.getLogger(LongitudinalSectionGenerator.class); public static final String I18N_CHART_TITLE = "chart.longitudinal.section.title"; public static final String I18N_ANNOTATIONS_LABEL = "chart.longitudinal.annotations.label"; public static final String I18N_CHART_SUBTITLE = "chart.longitudinal.section.subtitle"; public static final String I18N_XAXIS_LABEL = "chart.longitudinal.section.xaxis.label"; public static final String I18N_YAXIS_LABEL = "chart.longitudinal.section.yaxis.label"; public static final String I18N_2YAXIS_LABEL = "chart.longitudinal.section.yaxis.second.label"; public static final String I18N_CHART_TITLE_DEFAULT = "W-L\u00e4ngsschnitt"; public static final String I18N_XAXIS_LABEL_DEFAULT = "km"; public static final String I18N_YAXIS_LABEL_DEFAULT = "W [NN + m]"; public static final String I18N_2YAXIS_LABEL_DEFAULT = "Q [m\u00b3/s]"; protected boolean inverted; public LongitudinalSectionGenerator() { super(); } protected String getChartTitle() { return msg(I18N_CHART_TITLE, I18N_CHART_TITLE_DEFAULT); } public boolean isInverted() { return inverted; } public void setInverted(boolean inverted) { this.inverted = inverted; } @Override protected void addSubtitles(JFreeChart chart) { double[] dist = getRange(); Object[] args = new Object[] { getRiverName(), dist[0], dist[1] }; String subtitle = msg(I18N_CHART_SUBTITLE, "", args); chart.addSubtitle(new TextTitle(subtitle)); } protected String getXAxisLabel() { FLYSArtifact flys = (FLYSArtifact) master; return msg( I18N_XAXIS_LABEL, I18N_XAXIS_LABEL_DEFAULT, new Object[] { FLYSUtils.getRiver(flys).getName() }); } protected String getYAxisLabel() { FLYSArtifact flys = (FLYSArtifact) master; String unit = FLYSUtils.getRiver(flys).getWstUnit().getName(); return msg( I18N_YAXIS_LABEL, I18N_YAXIS_LABEL_DEFAULT, new Object[] { unit }); } protected void adjustAxes(XYPlot plot) { super.adjustAxes(plot); NumberAxis qAxis = new NumberAxis( msg(I18N_2YAXIS_LABEL, I18N_2YAXIS_LABEL_DEFAULT)); plot.setRangeAxis(1, qAxis); invertXAxis(plot.getDomainAxis()); } /** * Create a range that includes 0 (for the Q axis). * @param range range with which to look up upper bound. * @return range with 0 included. */ protected Range createSecondAxisRange(Range range) { return new Range(0d, range.getUpperBound()); } /** * This method overrides the XYChartGenerators zoomY method to be able to * modify the range of the Q axis (here, it shall include 0). */ @Override protected boolean zoomY(XYPlot plot, ValueAxis axis, Range range, Range x) { if (plot.getRangeAxisIndex(axis) == 1) { // We want the Q axis to start at 0 if no zooming has been done. range = createSecondAxisRange(range); } return super.zoomY(plot, axis, range, x); } /** * This method inverts the x-axis based on the kilometer information of the * selected river. If the head of the river is at kilometer 0, the axis is * not inverted, otherwise it is. * * @param xaxis The domain axis. */ protected void invertXAxis(ValueAxis xaxis) { if (inverted) { logger.debug("Invert X-Axis."); xaxis.setInverted(true); } } public void doOut( Artifact artifact, Facet facet, Document attr, boolean visible ) { String name = facet.getName(); logger.debug("LongitudinalSectionGenerator.doOut: " + name); if (name == null) { logger.error("No facet name for doOut(). No output generated!"); return; } FLYSArtifact flys = (FLYSArtifact) artifact; Facet f = flys.getNativeFacet(facet); if (f == null) { return; } if (name.equals(LONGITUDINAL_W)) { doWOut((WQKms) f.getData(artifact, context), attr, visible); } else if (name.equals(LONGITUDINAL_Q)) { doQOut((WQKms) f.getData(artifact, context), attr, visible); } else if (name.equals(LONGITUDINAL_ANNOTATION)) { doAnnotationsOut(f.getData(artifact, context), attr, visible); } else { logger.warn("Unknown facet name: " + name); return; } } /** * Register annotations available for the diagram. * * @param o list of annotations (data of facet). * @param theme yet ignored. */ protected void doAnnotationsOut(Object o, Document theme, boolean visible) { logger.debug("LongitudinalSectionGenerator.doAnnotationsOut"); // Add all annotations in list o to our annotation pool. FLYSAnnotation fa = (FLYSAnnotation) o; addAnnotations(fa, visible); } /** * Process the output for W facets in a longitudinal section curve. * * @param wqkms An array of WQKms values. * @param theme The theme that contains styling information. */ protected void doWOut(WQKms wqkms, Document theme, boolean visible) { logger.debug("LongitudinalSectionGenerator.doWOut"); XYSeries series = new StyledXYSeries(getSeriesName(wqkms, "W"), theme); int size = wqkms.size(); boolean wsUp = wqkms.guessWaterIncreasing(); boolean kmUp = DataUtil.guessWaterIncreasing(wqkms.allKms()); boolean inv = !(kmUp && !wsUp); if (logger.isDebugEnabled()) { logger.debug("Generate series: " + series.getKey()); logger.debug("Values : " + size); if (size > 0) { logger.debug("Start km: " + wqkms.getKm(0)); logger.debug("End km: " + wqkms.getKm(size-1)); } logger.debug("wsUp: " + wsUp); logger.debug("kmUp: " + kmUp); logger.debug("inv: " + inv); } for (int i = 0; i < size; i++) { series.add(wqkms.getKm(i), wqkms.getW(i)); } addFirstAxisSeries(series, visible); if (inv) { setInverted(true); } } /** * Process the output for Q facets in a longitudinal section curve. * * @param wqkms An array of WQKms values. * @param theme The theme that contains styling information. */ protected void doQOut(WQKms wqkms, Document theme, boolean visible) { logger.debug("LongitudinalSectionGenerator.doQOut"); XYSeries series = new StyledXYSeries(getSeriesName(wqkms, "Q"), theme); int size = wqkms.size(); if (logger.isDebugEnabled()) { if (wqkms.size() > 0) { logger.debug("Generate series: " + series.getKey()); logger.debug("Start km: " + wqkms.getKm(0)); logger.debug("End km: " + wqkms.getKm(size-1)); logger.debug("Values : " + size); } } for (int i = 0; i < size; i++) { series.add(wqkms.getKm(i), wqkms.getQ(i)); } addSecondAxisSeries(series, visible); //if (wqkms.guessWaterIncreasing()) { // setInverted(true); //} } /** * Get name of series (displayed in legend). * @return name of the series. */ protected String getSeriesName(WQKms wqkms, String mode) { String name = wqkms.getName(); String prefix = name != null && name.indexOf(mode) >= 0 ? null : mode; return prefix != null && prefix.length() > 0 ? prefix + "(" + name +")" : name; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :