Mercurial > mxd2map
view src/java/de/intevation/mxd/reader/MultiLayerLineSymbolReader.java @ 115:fb93f20478cc
Improved exception handling for symbol reader.
author | Raimund Renkert <rrenkert@intevation.de> |
---|---|
date | Wed, 15 Jun 2011 16:48:42 +0200 |
parents | 59e06c405a9a |
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.ILineSymbol; import com.esri.arcgis.display.MultiLayerLineSymbol; import org.w3c.dom.Element; /** * Reads multi layer line symbol information. * * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a> */ public class MultiLayerLineSymbolReader extends AbstractSymbolReader { /** * The logger. */ private static final Logger logger = Logger.getLogger(MultiLayerLineSymbolReader.class); /** * Private member. */ private MultiLayerLineSymbol symbol; public MultiLayerLineSymbolReader(ISymbol symbol) throws Exception { logger.debug("contructor()"); if(symbol instanceof MultiLayerLineSymbol) { this.symbol = (MultiLayerLineSymbol)symbol; } else { throw new Exception("Not a MultiLayerLineSymbol!"); } } public MultiLayerLineSymbolReader(ILineSymbol symbol) throws Exception { logger.debug("contructor()"); if(symbol instanceof MultiLayerLineSymbol) { this.symbol = (MultiLayerLineSymbol)symbol; } else { throw new Exception("Not a MultiLayerLineSymbol!"); } } /** * 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); ISymbolReader sreader = new LineSymbolReader(sym); sreader.setParent(parent); sreader.setUtil(util); sreader.read(); } } 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 :