view artifacts/src/main/java/org/dive4elements/river/exports/process/BedHeightProcessor.java @ 7723:272cbcd94688

Make GAP_TOLERANCE static
author Andre Heinecke <aheinecke@intevation.de>
date Fri, 20 Dec 2013 18:49:54 +0100
parents f1257717fa4b
children b2a8a94a92f9
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.process;

import java.util.List;

import org.apache.log4j.Logger;
import org.jfree.data.xy.XYSeries;

import org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
import org.dive4elements.artifacts.CallContext;
import org.dive4elements.river.artifacts.D4EArtifact;
import org.dive4elements.river.artifacts.model.minfo.BedHeightSingleData;
import org.dive4elements.river.artifacts.model.minfo.BedDiffYearResult;
import org.dive4elements.river.artifacts.model.FacetTypes;
import org.dive4elements.river.exports.XYChartGenerator;
import org.dive4elements.river.exports.DiagramGenerator;
import org.dive4elements.river.exports.StyledSeriesBuilder;
import org.dive4elements.river.jfree.StyledXYSeries;
import org.dive4elements.river.model.BedHeightSingleValue;
import org.dive4elements.river.themes.ThemeDocument;
import org.dive4elements.river.utils.RiverUtils;

public class BedHeightProcessor extends DefaultProcessor {

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

    public static final String I18N_AXIS_LABEL_DEFAULT
        = "Sohlhoehe [m]";
    public static final String I18N_AXIS_LABEL =
        "chart.bedheight.height.yaxis.label";

    protected static final double GAP_TOLERANCE = 0.101d;

    @Override
    public void doOut(
            DiagramGenerator generator,
            ArtifactAndFacet bundle,
            ThemeDocument    theme,
            boolean          visible) {
        XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
        generator.addAxisSeries(series, axisName, visible);
    }

    @Override
    public void doOut(
            XYChartGenerator generator,
            ArtifactAndFacet bundle,
            ThemeDocument theme,
            boolean visible,
            int index
    ) {
        XYSeries series = prepareSeries(bundle, theme, generator.getCallContext());
        generator.addAxisSeries(series, index, visible);
    }

    /** Prepare an series, independent of axis. */
    private XYSeries prepareSeries(ArtifactAndFacet bundle,
        ThemeDocument theme, CallContext context) {
        Object data = bundle.getData(context);
        XYSeries series = new StyledXYSeries(bundle.getFacetDescription(),
                theme);
        if (data instanceof BedDiffYearResult) {
            BedDiffYearResult bData = (BedDiffYearResult) data;

            double[][] points;
            String facetType = bundle.getFacetName();

            if (FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1.equals(facetType) ||
                FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1_FILTERED.equals(facetType)) {
                points = bData.getHeights1Data();
            } else {
                points = bData.getHeights2Data();
            }
            StyledSeriesBuilder.addPointsFactorY(series,
                    points,
                    false,
                    GAP_TOLERANCE,
                    1d);
        } else if (data instanceof BedHeightSingleData) {
            BedHeightSingleData bData = (BedHeightSingleData)data;
            double[] heights  = bData.getHeights();
            double[] stations = bData.getStations().toNativeArray();

            logger.debug("doBedheightSingleOut");

            for (int i = 0; i < heights.length; i++) {
                series.add(stations[i], heights[i], false);
            }
        }
        else if (data instanceof List<?>) {
            List<BedHeightSingleValue> bData = (List<BedHeightSingleValue>)data;

            logger.debug("doBedheightSingleValueOut");

            for(BedHeightSingleValue bvalue: bData) {
                series.add(bvalue.getStation(), bvalue.getHeight());
            }
        }
        else {
            logger.error("Unknown data type " + data.getClass());
        }
        return series;
    }


    @Override
    public boolean canHandle(String facetType) {
        return FacetTypes.BEDHEIGHT.equals(facetType)
            || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1.equals(facetType)
            || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT2.equals(facetType)
            || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT1_FILTERED.equals(facetType)
            || FacetTypes.BED_DIFFERENCE_YEAR_HEIGHT2_FILTERED.equals(facetType);
    }

    @Override
    public String getAxisLabel(DiagramGenerator generator) {
        D4EArtifact flys = (D4EArtifact) generator.getMaster();

        String unit = RiverUtils.getRiver(flys).getWstUnit().getName();

        return generator.msg(
                I18N_AXIS_LABEL,
                I18N_AXIS_LABEL_DEFAULT,
                new Object[] { unit });
    }
}

http://dive4elements.wald.intevation.org