annotate src/java/de/intevation/mxd/reader/UniqueValueRendererReader.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 6c3d880db7c5
children acc9e5430177
rev   line source
33
c51376f8e24c Separated converter components into packages.
Raimund Renkert <rrenkert@intevation.de>
parents: 31
diff changeset
1 package de.intevation.mxd.reader;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
2
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
3 import org.apache.log4j.Logger;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
4
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
5 import com.esri.arcgis.carto.IFeatureRenderer;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
6 import com.esri.arcgis.display.ISymbol;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
7 import com.esri.arcgis.carto.UniqueValueRenderer;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
8
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
9 import org.w3c.dom.Element;
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
10 import java.io.IOException;
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
11
33
c51376f8e24c Separated converter components into packages.
Raimund Renkert <rrenkert@intevation.de>
parents: 31
diff changeset
12 import de.intevation.mxd.utils.MapToXMLUtils;
c51376f8e24c Separated converter components into packages.
Raimund Renkert <rrenkert@intevation.de>
parents: 31
diff changeset
13
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 /**
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 * Reads unique vaule renderer information.
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
16 *
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17 * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a>
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18 */
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
19 public class UniqueValueRendererReader
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
20 implements IRendererReader {
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
21
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
22 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
23 * The logger.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
24 */
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
25 private static final Logger logger =
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
26 Logger.getLogger(FeatureLayerReader.class);
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
27
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
28 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
29 * Private Member.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
30 */
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
31 private UniqueValueRenderer renderer;
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
32 private Element layer;
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
33 private MapToXMLUtils util;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
36 public UniqueValueRendererReader(IFeatureRenderer renderer)
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
37 throws Exception {
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
38 logger.debug("constructor()");
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
39 if (renderer instanceof UniqueValueRenderer) {
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
40 this.renderer = (UniqueValueRenderer)renderer;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
41 }
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
42 else {
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
43 throw new Exception ("Not an instance of UniqueValueRenderer.");
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
44 }
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
45 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
46
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
47 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
48 * Setter for the parent XML element.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
49 *
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
50 * @param parent The XML parent node.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
51 */
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
52 public void setParent(Element parent) {
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
53 this.layer = parent;
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
54 }
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
55
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
56 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
57 * Setter for XML document helper.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
58 *
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
59 * @param util The helper class for storing map information.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
60 */
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
61 public void setUtil(MapToXMLUtils util) {
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
62 this.util = util;
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
63 }
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
64
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
65 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
66 * Reads the renderer attributes.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
67 *
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
68 * @return The parent XML node.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
69 */
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
70 public Element read() {
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
71 logger.debug("read()");
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
72 int count = 0;
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
73 try {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
74 count = renderer.getClassCount();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
75 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
76 catch(IOException ioe) {
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 116
diff changeset
77 logger.error(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 116
diff changeset
78 "Could not read class count."+
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 116
diff changeset
79 " Stopped reading renderer.");
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
80 return layer;
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
81 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
82 for(int i = 0; i < count - 1; i++) {
74
7eba97e8201b Catch all exceptions in the MXDReader.
Raimund Renkert <rrenkert@intevation.de>
parents: 73
diff changeset
83 Element rendererElement = util.addRenderer(layer);
73
acbe36fb45e0 Use the wrapper in the renderer reader to read symbols.
Raimund Renkert <rrenkert@intevation.de>
parents: 70
diff changeset
84
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
85 try {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
86 String value = renderer.getValue(i);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
87 rendererElement.setAttribute("name", renderer.esri_getClass(i));
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
88 rendererElement.setAttribute("description",
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
89 renderer.getDescription(value));
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
90 rendererElement.setAttribute("value", value);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
91 rendererElement.setAttribute("label", renderer.getLabel(value));
74
7eba97e8201b Catch all exceptions in the MXDReader.
Raimund Renkert <rrenkert@intevation.de>
parents: 73
diff changeset
92 rendererElement.setAttribute(
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
93 "field_count",
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
94 String.valueOf(renderer.getFieldCount()));
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
95 for(int j = 0; j < renderer.getFieldCount(); j++) {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
96 rendererElement.setAttribute(
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
97 "expression_field_" + j,
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
98 renderer.getField(j));
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
99 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
100 rendererElement.setAttribute("expression_operator", "=");
74
7eba97e8201b Catch all exceptions in the MXDReader.
Raimund Renkert <rrenkert@intevation.de>
parents: 73
diff changeset
101
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
102 ISymbol sym = renderer.getSymbol(value);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
103 MarkerSymbolReader markerReader = new MarkerSymbolReader();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
104 LineSymbolReader lineReader = new LineSymbolReader();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
105 FillSymbolReader fillReader = new FillSymbolReader();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
106 if(markerReader.canRead(sym)) {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
107 markerReader.setSymbol(sym);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
108 markerReader.setUtil(util);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
109 markerReader.setParent(rendererElement);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
110 markerReader.read();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
111 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
112 else if(lineReader.canRead(sym)) {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
113 lineReader.setSymbol(sym);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
114 lineReader.setUtil(util);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
115 lineReader.setParent(rendererElement);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
116 lineReader.read();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
117 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
118 else if(fillReader.canRead(sym)) {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
119 fillReader.setSymbol(sym);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
120 fillReader.setUtil(util);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
121 fillReader.setParent(rendererElement);
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
122 fillReader.read();
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
123 }
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
124 else {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
125 logger.debug("Not a known symbol type: " +
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
126 sym.getClass().toString());
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
127 }
74
7eba97e8201b Catch all exceptions in the MXDReader.
Raimund Renkert <rrenkert@intevation.de>
parents: 73
diff changeset
128 }
116
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
129 catch(Exception e) {
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
130 logger.error(
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
131 "Could not read unique value data." +
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
132 e.toString());
c8a1361ddd38 Improved exceptionhandlin for renderer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
133 return layer;
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
134 }
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
135 }
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
136 return layer;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
137 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
138 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
139 // 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)