Mercurial > mxd2map
view src/java/de/intevation/mxd/reader/CompositeGraphicsLayerReader.java @ 335:4cf94b919725
* src/java/de/intevation/mxd/writer/MapScriptWriter.java:
Fix Label handling according to mapscript 6.2
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Fri, 26 Oct 2012 12:46:41 +0200 |
parents | b6c0fbae16dc |
children |
line wrap: on
line source
/* * Copyright (c) 2012 by Intevation GmbH, Germany <info@intevation.de> * * This file is part of MXD2map. * * This program is free software under the LGPL (>=v2.1) * Read the file LICENCE.txt coming with the software for details * or visit http://www.gnu.org/licenses/ if it does not exist. * * MXD2map has been developed on behalf of the * Bundesamt fuer Seeschifffahrt und Hydrographie (BSH) in Hamburg * by Intevation GmbH. * * Authors: * Raimund Renkert <raimund.renkert@intevation.de> * Bjoern Schilberg <bjoern.schilberg@intevation.de> * Stephan Holl <stephan.holl@intevation.de> * Andre Heinecke <aheinecke@intevation.de> */ package de.intevation.mxd.reader; import org.apache.log4j.Logger; import com.esri.arcgis.carto.IGraphicsLayer; import com.esri.arcgis.carto.ILayer; import com.esri.arcgis.carto.CompositeGraphicsLayer; import com.esri.arcgis.carto.GraphicsSubLayer; import com.esri.arcgis.carto.AnnotateLayerPropertiesCollection; import com.esri.arcgis.carto.IAnnotateLayerProperties; import com.esri.arcgis.carto.LabelEngineLayerProperties; import com.esri.arcgis.carto.IElement; import com.esri.arcgis.carto.TextElement; import com.esri.arcgis.system.IName; import com.esri.arcgis.system.IPropertySet; import com.esri.arcgis.geometry.Envelope; import com.esri.arcgis.geometry.ISpatialReference; import com.esri.arcgis.geometry.ProjectedCoordinateSystem; import com.esri.arcgis.geometry.GeographicCoordinateSystem; import com.esri.arcgis.geometry.UnknownCoordinateSystem; import com.esri.arcgis.geometry.Projection; import com.esri.arcgis.geometry.IPoint; import com.esri.arcgis.display.ITextSymbol; import com.esri.arcgis.display.TextSymbol; import org.w3c.dom.Element; import de.intevation.mxd.utils.MapToXMLUtils; import java.io.IOException; import com.esri.arcgis.interop.AutomationException; /** * Reads Layer information. * * @author <a href="mailto:aheinecke@intevation.de">Andre Heinecke</a> */ public class CompositeGraphicsLayerReader implements ILayerReader { /** * The logger. */ private static final Logger logger = Logger.getLogger(CompositeGraphicsLayerReader.class); /** * Privte member. */ private CompositeGraphicsLayer layer; private MapToXMLUtils util; /** * Constructor with layer. * * @param layer The ArcGIS layer object. */ public CompositeGraphicsLayerReader(IGraphicsLayer layer) throws Exception { if(layer instanceof CompositeGraphicsLayer) { this.layer = (CompositeGraphicsLayer)layer; } else { throw new Exception("Not an instance of CompositeGraphicsLayer: " + layer.getClass().toString()); } } /** * Setter for XML document helper. * * @param util The helper for storing map information. */ public void setUtil(MapToXMLUtils util) { this.util = util; } /** * Reads the Layer content. * * @return The layer XML element. */ public Element read() throws IOException{ logger.debug("read()"); Element layerElement = null; try { layerElement = util.addLayer(); } catch(Exception e) { logger.error("Failed to create DOM-Element for Layer."); return null; } // Name try { layerElement.setAttribute("name", layer.getName()); } catch(Exception e) { logger.warn( "Could not read layer name." + " Stopped reading layer."); throw new IOException("Error reading layer name."); } // Scale try { layerElement.setAttribute("min_scale", String.valueOf(layer.getMinimumScale())); } catch(IOException ioe) { logger.warn("Could not read minimum scale."); } try { layerElement.setAttribute("max_scale", String.valueOf(layer.getMaximumScale())); } catch(Exception e) { logger.warn( "Could not read maximum scale."); } // Status try { if(layer.isVisible()) { layerElement.setAttribute("status", "on"); } else { layerElement.setAttribute("status", "off"); } } catch(Exception e) { logger.warn( "Could not read layer status." + " Setting layer status to \"on\"."); layerElement.setAttribute("status", "on"); } // Extent try { Envelope rect = (Envelope)layer.getExtent(); layerElement.setAttribute( "extent_min_x", String.valueOf(rect.getXMin ())); layerElement.setAttribute( "extent_max_x", String.valueOf(rect.getXMax())); layerElement.setAttribute( "extent_min_y", String.valueOf(rect.getYMin())); layerElement.setAttribute( "extent_max_y", String.valueOf(rect.getYMax())); } catch(Exception e) { logger.warn( "Could not read extent from layer " + layer.getName() + "."); } // Read the elements try { int count = 0; IElement actElement = null; IElement prevElement = null; layer.reset(); // Reset the element container actElement = layer.next(); while (actElement != prevElement) { prevElement = actElement; if (actElement instanceof TextElement) { TextElement te = (TextElement)actElement; Element xmlTextElement = util.addFeature(layerElement); xmlTextElement.setAttribute("text", te.getText()); IPoint poi = te.getGeometry().getEnvelope().getLowerLeft(); xmlTextElement.setAttribute("X", String.valueOf(poi.getX())); xmlTextElement.setAttribute("Y", String.valueOf(poi.getY())); xmlTextElement.setAttribute("classId", String.valueOf(count)); try { ITextSymbol sym = te.getSymbol(); if(sym instanceof TextSymbol) { TextSymbolReader tsr = new TextSymbolReader(sym); tsr.setParent(xmlTextElement); tsr.setUtil(util); tsr.read(); } else { logger.warn("Unknwon Symbol of class: " + sym.getClass().toString()); } } catch(Exception e) { logger.warn("Could not read element text symbol."); } } else { logger.warn("Unhandled Element of class: " + actElement.getClass().toString() + " in conversion of layer: " + layer.getName()); } count++; actElement = layer.next(); } } catch(Exception e) { logger.warn("Could not read layer elements."); logger.debug(e); } //Read the projection. try { ISpatialReference sr = layer.getSpatialReference(); int projection = 0; if(sr instanceof ProjectedCoordinateSystem) { ProjectedCoordinateSystem pcs = (ProjectedCoordinateSystem)sr; projection = pcs.getFactoryCode(); } else if(sr instanceof GeographicCoordinateSystem) { GeographicCoordinateSystem gcs = (GeographicCoordinateSystem)sr; projection = gcs.getFactoryCode(); } else if(sr instanceof UnknownCoordinateSystem) { UnknownCoordinateSystem ucs = (UnknownCoordinateSystem)sr; projection = 0; } else{ logger.debug( "Unknown SpatialReference: " + sr.getClass().toString()); } if(projection == 0) { logger.warn( "Unknown projection for Layer:" + layer.getName() + " Please edit projection in resulting mapfile."); } layerElement.setAttribute("projection", String.valueOf(projection)); } catch(Exception e) { logger.warn("Could not read layer projection."); logger.debug(e); } // Static values for this layer layerElement.setAttribute("type", "annotation"); // Read Sublayers for (int i = 0; i < layer.getCount(); i++) { ILayer pLyr = layer.getLayer(i); GraphicsSubLayer subbie = new GraphicsSubLayer((Object)pLyr); if (subbie != null) { GraphicsSubLayerReader lr = new GraphicsSubLayerReader(subbie); lr.setUtil(util); lr.read(); } else { logger.warn("Could not convert sublayer to GraphicsSubLayer"); } } return layerElement; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :