Mercurial > mxd2map
view src/java/de/intevation/mxd/reader/MultiLayerFillSymbolReader.java @ 121:9f74f4d36822
Set default values and improved logging and exception handling for map reader.
author | Raimund Renkert <rrenkert@intevation.de> |
---|---|
date | Thu, 16 Jun 2011 18:36:48 +0200 |
parents | fb93f20478cc |
children | 0bde090506f9 |
line wrap: on
line source
package de.intevation.mxd.reader; import org.apache.log4j.Logger; import com.esri.arcgis.display.ISymbol; import com.esri.arcgis.display.IFillSymbol; import com.esri.arcgis.display.MultiLayerFillSymbol; import org.w3c.dom.Element; /** * Reads multi layer line symbol information. * * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> */ public class MultiLayerFillSymbolReader extends AbstractSymbolReader { /** * The logger. */ private static final Logger logger = Logger.getLogger(MultiLayerFillSymbolReader.class); /** * Private member. */ private MultiLayerFillSymbol symbol; public MultiLayerFillSymbolReader(ISymbol symbol) throws Exception { logger.debug("contructor()"); if(symbol instanceof MultiLayerFillSymbol) { this.symbol = (MultiLayerFillSymbol)symbol; } else { throw new Exception("Not a MultiLayerFillSymbol!"); } } public MultiLayerFillSymbolReader(IFillSymbol symbol) throws Exception { logger.debug("contructor()"); if(symbol instanceof MultiLayerFillSymbol) { this.symbol = (MultiLayerFillSymbol)symbol; } else { throw new Exception("Not a MultiLayerFillSymbol!"); } } /** * Reads the symbol attributes. * * @return The XML node. */ public Element read() { logger.debug("read()"); try { for(int i = 0; i < symbol.getLayerCount(); i++) { ISymbol sym = (ISymbol)symbol.getLayer(i); FillSymbolReader fsr = new FillSymbolReader(); if(fsr.canRead(sym)) { fsr.setSymbol(sym); fsr.setParent(parent); fsr.setUtil(util); fsr.read(); } else { logger.debug("The type of " + sym.getClass().toString() + " is not implemented!"); } } } catch(Exception e) { logger.error( "Could not read the symbol " + symbol.getClass().toString()); } return parent; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :