view artifacts/src/main/java/org/dive4elements/river/exports/process/Processor.java @ 7076:7f600001c807 generator-refactoring

Add LTR inversion code to diagram generator. This code is used in serveral diagrams and as it modifies a whole diagram it should be central. (This should also make maintenance easier). This function can be called by processors to make sure that their data is plotted with an LTR waterflow.
author Andre Heinecke <aheinecke@intevation.de>
date Fri, 20 Sep 2013 16:33:22 +0200
parents 253d80af5b7f
children f0731aa7b735
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 org.dive4elements.artifactdatabase.state.ArtifactAndFacet;
import org.dive4elements.river.exports.XYChartGenerator;
import org.dive4elements.river.themes.ThemeDocument;
import org.dive4elements.river.exports.DiagramGenerator;

/**
 * A processor is intended to generate an output e.g. curve in a chart diagramm from
 * arbitrary data input which can be reused in several generators.
 *
 * @author <a href="mailto:bjoern.ricks@intevation.de">Björn Ricks</a>
 */
public interface Processor {
    /**
     * Set the axis for this processor.
     * This should be done before doOut is called for the first time.
     *
     * @param axisName The name of the Axis this processor should use.
     */
    public void setAxisName(String axisName);

    /**
     * Get the axis for this processor.
     *
     * @return The name of the axis that is used.
     */
    public String getAxisName();

    /**
     * Processes data to generate e.g. a chart.
     *
     * @param generator XYChartGenerator to add output on.
     * @param bundle     The artifact and facet
     * @param theme     The theme that contains styling information.
     * @param visible   The visibility of the curve.
     */
    public void doOut(
            DiagramGenerator generator,
            ArtifactAndFacet bundle,
            ThemeDocument    theme,
            boolean          visible);

    /**
     * Processes data to generate e.g. a chart.
     *
     * @param generator DiagramGenerator to add output on.
     * @param bundle     The artifact and facet
     * @param theme     The theme that contains styling information.
     * @param visible   The visibility of the curve.
     * @param index     The index of the curve
     */
    @Deprecated
    public void doOut(
            XYChartGenerator generator,
            ArtifactAndFacet bundle,
            ThemeDocument    theme,
            boolean          visible,
            int              index);

    /**
     * Returns true if the Processor class is able to generate output for a facet type
     *
     * @param facettype Name of the facet type
     * @return true if the facettype can be processed
     */
    public boolean canHandle(String facettype);
}

http://dive4elements.wald.intevation.org