Mercurial > dive4elements > river
view artifacts/src/main/java/org/dive4elements/river/exports/DischargeLongitudinalSectionExporter.java @ 9429:bd5f5d2220fa
Work on salix cross sections; waterlevels work now with different colors
Colors and i10n for all themes.
author | gernotbelger |
---|---|
date | Fri, 17 Aug 2018 17:48:01 +0200 |
parents | 740d65e4aa14 |
children |
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde * Software engineering by Intevation GmbH * * This file is Free Software under the GNU AGPL (>=v3) * and comes with ABSOLUTELY NO WARRANTY! Check out the * documentation coming with Dive4Elements River for details. */ package org.dive4elements.river.exports; import java.text.NumberFormat; import org.apache.log4j.Logger; import org.dive4elements.river.artifacts.model.CalculationResult; import org.dive4elements.river.artifacts.model.WQCKms; import org.dive4elements.river.artifacts.model.WQKms; import au.com.bytecode.opencsv.CSVWriter; /** * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class DischargeLongitudinalSectionExporter extends WaterlevelExporter { /** The log used in this exporter. */ private static Logger log = Logger.getLogger(DischargeLongitudinalSectionExporter.class); public static final String CSV_KM_HEADER = "export.discharge.longitudinal.section.csv.header.km"; public static final String CSV_W_HEADER = "export.discharge.longitudinal.section.csv.header.w"; public static final String CSV_CW_HEADER = "export.discharge.longitudinal.section.csv.header.cw"; public static final String CSV_Q_HEADER = "common.export.csv.header.q"; public static final String DEFAULT_CSV_KM_HEADER = "Fluss-Km"; public static final String DEFAULT_CSV_W_HEADER = "W [NN + m]"; public static final String DEFAULT_CSV_CW_HEADER = "W korr."; public static final String DEFAULT_CSV_Q_HEADER = "Q [m\u00b3/s]"; @Override protected void addData(Object d) { if (d instanceof CalculationResult) { d = ((CalculationResult) d).getData(); if (d instanceof WQKms[]) { this.data.add((WQKms[]) d); } } } @Override protected void writeCSVHeader(final CSVWriter writer, final boolean atGauge, final boolean isQ) { log.info("WaterlevelExporter.writeCSVHeader"); writer.writeNext(new String[] { msg(CSV_KM_HEADER, DEFAULT_CSV_KM_HEADER), msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER), msg(CSV_CW_HEADER, DEFAULT_CSV_CW_HEADER), msg(CSV_Q_HEADER, DEFAULT_CSV_Q_HEADER), msg(CSV_Q_DESC_HEADER, DEFAULT_CSV_Q_DESC_HEADER) }); } @Override protected void wQKms2CSV(final CSVWriter writer, final WQKms wqkms, final boolean atGauge, final boolean isQ) { log.debug("WaterlevelExporter.wQKms2CSV"); final int size = wqkms.size(); double[] result = new double[4]; final NumberFormat kmf = getKmFormatter(); final NumberFormat wf = getWFormatter(); final NumberFormat qf = getQFormatter(); for (int i = 0; i < size; i++) { result = wqkms.get(i, result); final String name = wqkms.getName(); String wc = ""; if (wqkms instanceof WQCKms) { wc = wf.format(result[3]); } writer.writeNext(new String[] { kmf.format(result[2]), wf.format(result[0]), wc, qf.format(result[1]), name }); } } @Override protected void addWSTColumn(final WstWriter writer, final WQKms wqkms) { final String name = wqkms.getName(); // is it a W or a Q mode? final int wIdx = name.indexOf("W"); final int qIdx = name.indexOf("Q"); String wq = null; if (wIdx >= 0) { wq = "W"; } else if (qIdx >= 0) { wq = "Q"; } // we just want to display the first W or Q value in the WST final int start = name.indexOf("("); final int end = name.indexOf(")"); final String tmp = name.substring(start + 1, end); final String[] values = tmp.split(";"); final String column = wq + "=" + values[0]; writer.addColumn(column); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :