view src/java/de/intevation/mxd/reader/ClassBreakRendererReader.java @ 117:6c3d880db7c5

Improved exception handling for layer reader.
author Raimund Renkert <rrenkert@intevation.de>
date Thu, 16 Jun 2011 12:05:34 +0200
parents c8a1361ddd38
children 0f5819732288
line wrap: on
line source
package de.intevation.mxd.reader;

import java.lang.Exception;

import org.apache.log4j.Logger;

import com.esri.arcgis.carto.IFeatureRenderer;
import com.esri.arcgis.carto.ClassBreaksRenderer;
import com.esri.arcgis.display.ISymbol;

import org.w3c.dom.Element;

import de.intevation.mxd.utils.MapToXMLUtils;
import java.io.IOException;

/**
 * Reads the ClassBreaksRender Object Attributes.
 *
 * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a>
 */
public class ClassBreakRendererReader
implements IRendererReader {

    /**
     * The logger.
     */
    private static final Logger logger =
        Logger.getLogger(ClassBreakRendererReader.class);

    /**
     * Private member.
     */
    private ClassBreaksRenderer renderer;
    private Element layer;
    private MapToXMLUtils util;


    public ClassBreakRendererReader(IFeatureRenderer renderer)
    throws Exception {
        logger.debug("contructor()");
        if(renderer instanceof ClassBreaksRenderer)
            this.renderer = (ClassBreaksRenderer)renderer;
        else
            throw new Exception("Not a ClassBreaksRenderer!");
    }

    /**
     * Setter for the parent XML element.
     *
     * @param parent The XML parent node.
     */
    public void setParent(Element parent) {
        this.layer = parent;
    }

    /**
     * Setter for XML document helper.
     *
     * @param util The helper class for storing map information.
     */
    public void setUtil(MapToXMLUtils util) {
        this.util = util;
    }

    /**
     * Reads the Renderer attributes.
     *
     * @return The XML node.
     */
    public Element read() {
        logger.debug("read()");

        int count = 0;
        try {
            count = renderer.getBreakCount();
        }
        catch(IOException ioe) {
            logger.warn(
                "No break symbols found in renderer." +
                " Stopped reading this renderer.");
            return layer;
        }

        for(int i = 0; i < count; i++){
            Element rendererElement = util.addRenderer(layer);
            try {
                rendererElement.setAttribute("value",
                    String.valueOf(renderer.getBreak(i)));

                rendererElement.setAttribute(
                    "field_count",
                    String.valueOf(renderer.getFieldCount()));
                for(int j = 0; j < renderer.getFieldCount(); j++) {
                    rendererElement.setAttribute(
                        "expression_field_" + j,
                        renderer.getField(j));

                }
                rendererElement.setAttribute(
                    "min_value",
                    String.valueOf(renderer.getMinimumBreak()));
                rendererElement.setAttribute("expression_operator", "<=");

                ISymbol sym = renderer.getSymbol(i);
                MarkerSymbolReader markerReader = new MarkerSymbolReader();
                LineSymbolReader lineReader = new LineSymbolReader();
                FillSymbolReader fillReader = new FillSymbolReader();
                if(markerReader.canRead(sym)) {
                    markerReader.setSymbol(sym);
                    markerReader.setUtil(util);
                    markerReader.setParent(rendererElement);
                    markerReader.read();
                }
                else if(lineReader.canRead(sym)) {
                    lineReader.setSymbol(sym);
                    lineReader.setUtil(util);
                    lineReader.setParent(rendererElement);
                    lineReader.read();
                }
                else if(fillReader.canRead(sym)) {
                    fillReader.setSymbol(sym);
                    fillReader.setUtil(util);
                    fillReader.setParent(rendererElement);
                    fillReader.read();
                }
                else {
                    logger.debug("Not a known symbol type: " +
                                 sym.getClass().toString());
                }
            }
            catch(Exception e) {
                logger.error(
                    "Could not read data for " + i +
                    ". break of renderer. Stopped reading this renderer.");
                return layer;
            }
        }
        return layer;
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)