view flys-artifacts/src/main/java/de/intevation/flys/exports/MiddleBedHeightExporter.java @ 2792:fe987587ebc9

Merged revisions 4539-4540,4543,4545-4546 via svnmerge from file:///home/clients/bsh/bsh-generischer-viewer/Material/SVN/flys-artifacts/trunk ........ r4539 | teichmann | 2012-05-27 20:02:13 +0200 (So, 27 Mai 2012) | 1 line FixA: Added forgotten csv/report facets/generators to conf. ........ r4540 | teichmann | 2012-05-27 20:11:31 +0200 (So, 27 Mai 2012) | 1 line FixA: Fixed class cast bug in report facet. ........ r4543 | teichmann | 2012-05-28 20:35:01 +0200 (Mo, 28 Mai 2012) | 1 line FixA: Added facet to return delta w/t as CSV ........ r4545 | teichmann | 2012-05-28 22:59:27 +0200 (Mo, 28 Mai 2012) | 1 line FixA: Made Delta W/t calculation finally work ........ r4546 | teichmann | 2012-05-28 23:34:24 +0200 (Mo, 28 Mai 2012) | 1 line FixA: corrected fitting (Q->W instead W->Q). ........ flys-artifacts/tags/2.7@4547 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Tue, 29 May 2012 04:58:29 +0000
parents 2952f6dee5cf
children 2ff802d66b71
line wrap: on
line source
package de.intevation.flys.exports;

import java.io.OutputStream;
import java.text.NumberFormat;
import java.util.ArrayList;
import java.util.List;

import org.w3c.dom.Document;

import org.apache.log4j.Logger;

import au.com.bytecode.opencsv.CSVWriter;

import de.intevation.artifacts.CallContext;

import de.intevation.flys.artifacts.FLYSArtifact;
import de.intevation.flys.artifacts.model.CalculationResult;
import de.intevation.flys.artifacts.model.MiddleBedHeightData;
import de.intevation.flys.utils.FLYSUtils;
import de.intevation.flys.utils.Formatter;


/**
 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
 */
public class MiddleBedHeightExporter extends AbstractExporter {

    private static final Logger logger =
        Logger.getLogger(MiddleBedHeightExporter.class);


    public static final String CSV_KM =
        "export.bedheight_middle.csv.header.km";

    public static final String CSV_SOUNDING =
        "export.bedheight_middle.csv.header.sounding";

    public static final String CSV_HEIGHT =
        "export.bedheight_middle.csv.header.height";

    public static final String CSV_UNCERTAINTY =
        "export.bedheight_middle.csv.header.uncertainty";

    public static final String CSV_DATA_GAP =
        "export.bedheight_middle.csv.header.datagap";

    public static final String CSV_SOUNDING_WIDTH =
        "export.bedheight_middle.csv.header.soundingwidth";

    public static final String CSV_WIDTH =
        "export.bedheight_middle.csv.header.width";

    public static final String CSV_LOCATIONS =
        "export.bedheight_middle.csv.header.locations";


    protected List<MiddleBedHeightData[]> data;


    public void init(Document request, OutputStream out, CallContext cc) {
        super.init(request, out, cc);
        data = new ArrayList<MiddleBedHeightData[]>();
    }


    @Override
    protected void addData(Object d) {
        if (d instanceof CalculationResult) {
            d = ((CalculationResult) d).getData();

            if (d instanceof MiddleBedHeightData[]) {
                logger.debug("Add new data of type MiddleBedHeightData");
                data.add((MiddleBedHeightData[]) d);
            }
        }
    }


    @Override
    protected void writeCSVData(CSVWriter writer) {
        logger.info("MiddleBedHeightExporter.writeCSVData");
        logger.debug("CSV gets " + data.size() + " MiddleBedHeightData objects.");

        writeCSVHeader(writer);

        for (MiddleBedHeightData[] d: data) {
            data2CSV(writer, d);
        }
    }


    protected void writeCSVHeader(CSVWriter writer) {
        writer.writeNext(new String[] {
            msg(CSV_KM, CSV_KM),
            msg(CSV_SOUNDING, CSV_SOUNDING),
            msg(CSV_HEIGHT, CSV_HEIGHT),
            msg(CSV_UNCERTAINTY, CSV_UNCERTAINTY),
            msg(CSV_DATA_GAP, CSV_DATA_GAP),
            msg(CSV_SOUNDING_WIDTH, CSV_SOUNDING_WIDTH),
            msg(CSV_WIDTH, CSV_WIDTH),
            msg(CSV_LOCATIONS, CSV_LOCATIONS)
        });
    }


    protected void data2CSV(CSVWriter writer, MiddleBedHeightData[] mData) {
        logger.debug("Add next MiddleBedHeightData to CSV");

        FLYSArtifact flys = (FLYSArtifact) master;

        NumberFormat kmF     = Formatter.getMiddleBedHeightKM(context);
        NumberFormat heightF = Formatter.getMiddleBedHeightHeight(context);
        NumberFormat uncertF = Formatter.getMiddleBedHeightUncert(context);
        NumberFormat gapF    = Formatter.getMiddleBedHeightDataGap(context);
        NumberFormat soundF  = Formatter.getMiddleBedHeightSounding(context);
        NumberFormat widthF  = Formatter.getMiddleBedHeightWidth(context);

        for (MiddleBedHeightData data: mData) {
            for (int i = 0, n = data.size(); i < n; i++) {
                int start = data.getStartYear();
                int end   = data.getEndYear();

                if (start == end) {
                    writer.writeNext(new String[] {
                        kmF.format(data.getKM(i)),
                        data.getSoundingName(context),
                        heightF.format(data.getMiddleHeight(i)),
                        uncertF.format(data.getUncertainty(i)),
                        gapF.format(data.getDataGap(i)) + "%",
                        soundF.format(data.getSoundingWidth(i)),
                        widthF.format(data.getWidth(i)),
                        FLYSUtils.getLocationDescription(flys, data.getKM(i)),
                    });
                }
                else {
                    writer.writeNext(new String[] {
                        kmF.format(data.getKM(i)),
                        data.getSoundingName(context),
                        heightF.format(data.getMiddleHeight(i)),
                        "",
                        "",
                        "",
                        "",
                        FLYSUtils.getLocationDescription(flys, data.getKM(i)),
                    });
                }

            }
        }
    }


    @Override
    protected void writePDF(OutputStream out) {
        logger.error("TODO: Implement FlowVelocityExporter.writePDF");
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org